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I. INTRODUCTION 


A. VHSIC HARDWARE DESCRIPTION LANGUAGE (VHDL) 

While system standards such as the Unix and the X Window System continue to be 
refined and redefined, significant application-level standards are emerging. On one hand, 
there is explosive growth of electronic computer-aided engineering (CAE) and 
computer-aided design (CAD). On the other hand, because of the lack of a standard, 
numerous dissimilar and incompatible CAE;CAD databases have proliferated. 

New circuit designs inevitably will adopt part of old designs which were proven to 
be applicable even with a device technology break-through. Because of the large number 
of vendor-specific CAE’CAD formats, tools, and languages, the portability of designs 
are difficult, if not impossible. Consequently, designers tend to redevelop their designs 
in the new working environment rather than port the existing designs from another in- 
compatible working environment. Different formats and tools continue to grow. It 
causes system design to be even more inefficient. The need for an industry standard 1s 
apparent. 

When the Department of Defense launched the Very High Speed Integrated Circuit 
(VHSIC) project, it was confronted with the problems mentioned above. Furthermore, 
since most of the government systems tend to have a long service life, the last system 
On a given program might well be delivered fifteen years after the first production ship- 
ment. Both would be expected to remain in operation for at least ten years from that 
point in time. Technology, on the other hand, is irrevocably non-static. Technology 
used in the first delivery would be something quite different from those of twenty-five 


vears later. Yet. the operating svstems and their maintenance require compatible re- 


placement of components. Standardization, 1f 1t could accomplish this, could also assist 
in the procurements from second sources [Ref. 1]. 

In the early stage of the VHSIC program, an idea arose that these problems might 
be resolved through the development of a standard hardware description language 
(HDL). A program was launched in August of 1983 for the development of a VHSIC 
Hardware Description Language (VHDL) [Ref. 1]. 

The goal of the program was to develop a language which could simultaneouslv 
function as a design automation tool interface and as a mechanism for documenting the 
design of a transportable electronic system and its components. 

In August 1985, version 7.2 of the language was released by the Department of 
Defense. After the release of version 7.2, the IEEE sponsored the standardization. The 
goal was the development of an improved standard of the language. The review process 
was completed by May 1987 and the language reference manual (LRM) was released for 
industrial review. In December 1987 VHDL was accepted as JEEE-STD-1076-1987. 

Initially, the VHIDL was geared toward system-level design and documentation. 
However, after the design of the language has received inputs from many individuals in 
the computer industry, the VHDL offers not onlv behavioral constructs [Ref. 2] but also 
register transfer-level (RTL) and structural (1.e., gate level) constructs. The ist thus can 


describe a circuit at the register and the gate levels as well as the behavioral level. 


B. ERASABLE PROGRAMMABLE LOGIC DEVICE (EPLD) 

To achieve improved svstem performance in the marketplace, more and more man- 
ufacturers have sought higher levels of integration (functional density) for the electronic 
components in the design. This led to various forms of custom chips. Yet, the custom 


chips design has the following problems: 
I. Development lead times are relatively long. 


2. Design cost are significant. 


tJ 


3. Inventory 1s dedicated to a specific application which is expensive. This prohibits 
adequate second sources. 


4. Design changes in midstream are not allowed due to lead time and inventory con- 
straints. 


The concept of the erasable programmable logic device (EPLD) is to provide the 
user the benefits of large scale integration circuit without the drawbacks of full custom 
chips. The benefits of such parts include off-the-shelf availability, minimal design costs, 
multiple sourcing from distributors, and flexible interchangeable inventory. 

The EPLD basically consists of two parts. The first part is the conventional pro- 
grammable arrav logic (PAL) structure. The second part is a user-configurable 1/O 
control architecture. Inside the I/O control architecture there are signal path, select 
switches, and flip-flops. 

With improved techniques, the speed and functional density of EPLD’s are getting 
faster and higher. This makes the EPDL even more attractive. It is believed that more 


special purpose logic designs will use EPLD in place of the custom chips. 


C. EPLD MODELING 

In this study the VHDL language is used to model two EPLD chips, to find out 
what kind of problems will be encountered when modeling this type of chips, and to 
propose the VHDL solutions to these problems. 

The best way to describe the EPLD 1s at a register transfer level. In this study the 
Recister transier level models are used to stimulate both the EP310 and the EP1800. 
These devices are EPLD with approximately 300 and 2100 gates, respectively. 

A general introduction of the VHDL language and its working environment 1s the 
fame subjects of Chapter Il. In Chapter II] the structure of a small scale EPLD, EP310, 
is first introduced. It is followed by a general introduction of the EPLD’s design envi- 
ronment. Then, the specific problems encountered in modeling the EP310 chip are dis- 


cussed. Chapter IV introduces the modeling of a large scale EPLD, EP1800. The 


advantage and disadvantage of using the VHDL language in modeling a digital circuit 
design is discussed in Chapter V. At the end, Appendix A contains the VHDL source 
codes for the EP310 and the EP1800 models. Appendix B contains two simulation ap- 
plication VHDL sources files and their results. Appendix C contains an example of the 
signal select file used in the VHDL supporting environment and a signal map example 
which is produced by the VHDL supporting environment. Appendix D contains the 
procedures of constructing the EP310 model and the EP1800 model in the VHDL 1076 


standard supporting environment installed at the Naval Postgraduate School. 


Il. VHDL FEATURE AND ENVIRONMENT 


A. BASIC FEATURES OF VHDL 

This chapter constitutes a brief introduction of the VHDL. The advanced features 
of the VHDL and corresponding examples related to the EPROM modeling will be in- 
troduced later when thev are encountered. 

1. DESIGN ENTITIES 

In VHDL, a given section of a logic circuit 1s represented as a design entity. The 
logic circuit represented can be as complicated as an entire system or as simple as an 
AND gate. A design entity is defined by an entity declaration together with one or more 
corresponding architecture bodies as shown in Figure 1. 

An entity declaration basicallv defines the interface between a given design en- 
tity and the environment in which it is used. The actual relationship between these in- 
puts and outputs is specified in the architectural body. This body can specify the 
behavior of the entity directly such as a primitive body. The architectural bodv can also 
be structurally decomposed into simpler components. As shown in Figure’ 1. “Architec- 
ture A” is decomposed into smaller components. Each one of the components is an 
entity itself, and were binded to the “Architecture A” by “configuration specifications”. 

Illustrated below is an example that shows the basic features of an entity dec- 


laration. 


entity FULL_ADDER is 
generic(sum_delay,carry_delay: TIME: =25ns); 
poOurex.yeeim: in BIT: Zz,cout: out BIT); 


end FULL_ADDER: 


Entity 
Architecture 
Ri C 








Component declaration 


© 

© | Binding by 
Component declaration configuration 

o- specifications 


© 


Entity 


Architecture 


Figure 1. Scheme for various architectural bodies in one entity 
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Hmeventity name of the above example is “FULL ADDER’ and its ports are “x’, “y", 
“cin”, “Zz”, and “cout”. Each port has an associated mode, which identifies input, output, 
and an associated tvpe. In this case, all the signals have the same signal type, 1.e., BIT. 

The terms port and generic in the entity declaration above serve as the interface 
of the module. Port is used to pass the declared signals from external entity into the 
module. Generic is used to pass the parameters from the external entity into the module. 
With generic as an interface, it is possible to reuse a design entity whenever practical. 
For example, generic can be used to pass a faster delay parameter to the module to 
simulate a faster device. If the variable of a generic appear in a conditional signal as- 
signment statement, then the behavior of the design entitv may be chariged bv changing 
the value of that generic variable. 


Given the entity interface it is also necessary to specify what the 


“FULL_ADDER’” does in an architectural body. An example 1s shown below: 


architectural Data_Flow of FULL_ADDER is 
begin 
Z2<=x xor y xor cin after 20ns; 
cout<=(x and y)or(x and cin) or(y and cin) after 25ns;_ 


end Data_Flow; 


The structural body used in the above example is a behavioral description not 
involving the actual physical device. In most of the cases, the behavioral description 


model is the first step in building a real svstem. 





Figure 2. Full adder gate structure 


As mentioned before, a single entity may have several architectures corre- 
sponding to different ways of realizing the entity. Figure 2 is a physical structure of the 


"TULL_ADDER", and Figure 3 is the structural realization of it in VHDL. 


architectural STRUCTURAL of FULL_ADDER is 
begin 
component and_gate 
generic (delav: TIME := Sns); 
port (a,b:in BIT;c out BIT); 
end component; 
component xor_gate 
generic (delav: TIME := 5ns); 
port (a,b:in BIT;c out BIT); 
end component: 
component or_gate 
generic (delav: TIME := 5ns); 
port (a.b:in BIT:c out BIT); 
end component; 
signal locl, loc2, loc3: BIT; 
begin 
X1:xor_gate port map: (x,y,loc]); 
A2:xor_gate port map: (locl.cin,sum); 
Al:and_gate port map: (cin,locl ,loc2); 
A2:and_gate port map: (x,v.loc3): 
Ol:or_gate port map (loc?2,loc3, cout); 
pug oT RUCTLRAL; 





Figure 3.  Full_Adder VHDL structural description 


entity and_ gate is 
generic (delav: TIME := 5ns): 
port (a,b: in BIT; c: out BIT); 
end 


architecture BEHAVIOR of and_ gate is 
begin 
c <= aand b; 


end BEHAVIOR; 





Figure 4. Description of and_gate component 


entity or_gate is 
generic (delay: TIME := 5ns); 
port (a,b: in BIT; c: out BIT); 


end 


architecture BEHAVIOR of or_gate is 
begin 

c<=aorb; 
end BEHAVIOR; 





Figure 5. Description of or_gate component 


entity xor_gate is 
generic (delay: TIME :=5ns); 
port (a,b: in BIT; c: out BIT); 


end 


architecture BEHHAVIOR of xor_gate is 


begin 


c <= axorb; 
end BEHAVIOR; 





Figure 6. Description of Xor_gate component 


Three components, xor_gate, and_gate, and or_gate, are declared in the decla- 
ration section of the architecture “STRUCTURAL’ in Figure 3. The port specification 
used in the components of the “FULL_ADDER” indicates that there are two input sig- 
nal “a”, “b”, and an output signal “c”. The entity of these components have the identical 


port specifications as the “FLLL ADDER’ dose. (see Figure 4, figure Siang 


Figure 6). Three signals locl, loc2, and loc3 are also declared in the “FULL_ADDER’. 
These declared signals are local signals, which are visible only inside the 
“FULL _ ADDER’ entity. 

In the “FULL_ADDER’” entity, five components are instantiated after the key 
word begin; that is, five specific instances of general component entities are created. In 
each instantiation, there 1s a unique label associated with it (1.e., X1, X2, Al, A2, and 
Ol) as well as a port map. The generic map is optional. If the generic map is not stated 
in the instantiation, the assigned default value will be used. In the above case, since all 
the component instantiations does not state their generic map, the generics of the com- 
ponents will use their default value, 1.e., five nanosecond delay. 

The port map creates an association between the inputs/outputs of the compo- 
nent declaration and the signals in the instantiated components. In the 
“FULL_ADDER’ case the association is “by position”. Named association can also be 


used, which looks lke the following: 


Al: and_gate port map (c=>loc2, a=>cin, b=>cin); 


2. CONCURRENT STATEMENTS 

Some of the most important characteristics of the concurrent statements are 
described in this section. Concurrent statements are used to define interconnected 
blocks and processes that jointly describe the overall behavior or structure of a design 
entity. Concurrent statements are executed asynchronously with respect to each other. 

a. BLOCK STATEMENT 
The basic concurrent statement in VHDL 1s the block statement. The block 
consists of the declaration section as well as an executable section. The executable sec- 
tion can have all possible concurrent statements, which may include other block state- 
ments. The architectural body of the entity itself is basically a block. Consider the 


exaraple shown im Pigeure 7. Here, the architectural body “BLOCK_STRUCTURE’ can 


1] 


be seen as an outer block. The block “A” under the “BLOCK_STRUCTURE’” 1s its in- 
ner block. In general, any number of nestings of blocks are possible. Note that in Fig- 
ure 7 the text following the symbol ”--” are comments in VHDL and will not be 


executed. 


architecture BLOCK _STRUCTURE of FULL_ADDER is 
-- Outer Block Declaration Section 
signal loc] : BIT; 
begin 
-- Outer Block Executable Section 
locl <= x xor Vy after delay; 
sum < = locl xor cin after delay; 
A: block 
-- Inner Block A Declaration Section 
signal lacl,loc2,loc3,loc4 : BIT; 
begin 
-- Inner Block A Executable Section 
locl <= x and y after delay: 
loc2 <= vy and cin after delay; 
loc3 < = locl or loc2 after delay; 
loc4d < = loc3 or loc4 after delay; 
cout < = loc3 or loc4 after delay; 
end block A; 
end BLOCK SI RUCIURE. 





Figure 7. Example of nested blocks 


In VHDL, the block statement contains an optional guard expression. If 
there 1s an expression immediately following the key word block, then ich signal 
called guard with a type BOOLEAN will be created. The value of guard is dependent 
on the condition of the expression that follows the block. When a “guard condition” 
becomes TRUE, it can enable certain types of statements inside the block. By using a 


“guarded block” it 1s possible to model the operation of a synchronous circult. 


D type 


{lip-flop 





Figure $.  D latch block diagram 


eae) Latch is 
ban CLK CLR,D:in BIT; Q,Q not:out BIT); 
end D_ Latch; 


architecture GUARDED_CLOCK of D_Latch Its 
begin 
block(CLK=‘l’ or CLR=‘1’) 
Sienal 5: BIT; 
begin 
S <= guarded ‘0’ when CLR='l' else 
D: 





Q <= §S after 10ns; 
Q not <= nots after 10ns; 
end block: 
end GUARDED BLOCK; 





Figure 9. Example of D latch using guarded block 


A “guarded block” example is given by modeling the D latch as shown in 
Figure 8. This D latch will reflect the value of the input signal “d” when the clock 


(CLK) 1s high, 1.e., equal to ‘I’. The latch also contains an asynchronous clear (CLR) 
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input. When CLR = J], the latch 1s reset. The asynchronous clear overrides the clock. 
The corresponding latch model is shown in Figure 9. The block header expression 
“(CLK='l’ or CLR=‘1’)” define the value of the implicit guard. The statements con- 
tains the key word guarded will not be executed unless the value of guard is TRUE. In 
the D latch case, if the guard is FALSE, the local signal S will remain the same value. 
If the guard is TRUE and the CLR 1s a ‘1’, then S will be assigned to ‘0’; otherwise S 
will follow the input signal D. Note that the D latch illustrated above is a level-sensitive 
device. It will be shown in Chapter IJ] that the send is not restricted to level-sensitive. 
Edge-sensitive guard is available as well. 

b. PROCESS STATEMENT 

Another major modeling element in VHDL 1s the process. A process state- 
ment defines an independent sequential process. The process can represent the behavior 
of some portion of a design. An example is shown in Figure 10. Note that the process 
begin with the key word process(line). The parameter inside the parenthesis is called the 
sensitivity list. Whenever the signal inside the sensitivity list change, the process 1s ac- 
tivated and the statements within the process are executed. 
3. DATA TYPES 

The type is an important feature of VHDL. The VHDL is strongly typed, which 
means that inadvertent mixing of types in an operation will be flagged as an error. The 
strong typing features are very helpful for capturing the designer’s intent; they also help 
to check the design data-flow correctness. 

A type is characterized by a set of values and a set of operations. A subtype 1s 
a subset of the values of a tvpe. The set of operations defined for a subtype include the 
operations defined for the parent type; however, the assignment operation to an object 


having a given subtype only assigns values that belong to the subtype. 





process (linc) 
begin 
fiise -~ = | after dns, 0 after lons; 
end process; 


TIME (is) 





Figure 10. Process statement: (Pulse Converter) 


fereny tii) theesct of all integers are predelined as type INTEGER, and all 


positive iitegers are predefined as subtype POSITIVE in the following declaration 
subtype POSITIVE is INTEGER range 1 to INTEGER’ HIGH; 


Where the attribute “HIGH will vield the upper bound value of the INTEGER. Here, 
with the key word range the subtype POSITIVE will have the sane upper bound value 
as the INTEGER has. According to the subtype operation rule mentioned above, the 
subtraction operation implied for INTEGER, may not be used in subtype POSITIVE, 


because the subtraction of two positive numbers may produce a negative value. 


COMPOSITE 


ENUMERATION NN / SS 


RICAL PHYSICAL ARRAY 





Figure 11. VHDL data type classification scheme: [From Ref. 3] 


The “VHDL Language Reference Nfanual” gives a useful data tvpe classification 
scheme which is illustrated in Figure I!. Data types are classified as scalar (one- 
dimensional) or composite (multidimensional). The enwseration tvpe is the most fre- 


quently used scalar types. For example. the predefined type BIT 1s an enumeration type, 


which 1s defined as follows: 
type “BIT i sme) ae ae 
Numeric tvpes are either INTEGER or REAL. The REAL type Cangpeuge 


useful in modeling an anlog-to-digital interface or a signal processing algorithm. Some 


tvpe declaration examples are illustrated below: 


type INDEX is range 0 to 9; --integer type. 


type VOLTAGE is range 0.0 to 10.0; --real type. 


Each of the type declared in above example has a range. The base type (1.e., either IN- 
TEGER or REAL) is implied by the values in the range. 

The VHDL also provides the physical type, which is used to represent some 
physical quantities (such as, time, voltage, and capacity). TIME is a predefined physical 


type in VHDL, and its declaration is shown below: 


type TIME is range implementation_defined 


units 
fs; -- femtosecond 
ps = 1000fs; -- picosecond 
ns = 1000ps; -- nanosecond 
us = 1000ns; -- microsecond 
ms = 1000us; -- millisecond 
sec = 1000ms; -- second 
min = 60sec; -- minute 
hr = 60min; -- hour 


end units; 


Note that the base unit in TIME is femtoseconds (fs). Both the range and the base unit 
are user Selectable. But, the upper bound of the range cannot exceed the host machine 
limit. With the range from 0 to 1E20, the TIME can represent up to 27.7 hours (100,000 
second). 

The Composite tvpes are either array types or record types. Below is an array 


tvpe declaration example: 


type BYTE is array(0 to 7) of BIT; 


As declared above, BYTE is an array type of eight array elements. BIT is the 
base type of these array elements. Index range of the BYTE is constrained and is from 


“0 to 7”. Another example with unconstrained index range 1s shown below: 


type BIT_VECTOR is array( NATURAL range <>) of BIT; 


The expression “NATURAL” in BIT_VECTOR above means that the index has a 
subtype of natural number, 1.e., non negative number. The symbol” < >” following the 
key word range stands for an undefined range. The user must specify this range when 
it 1s emploved. For example, BIT VECTOR(O to 7) for ascending range, or 
BIT_VECTOR(7 downto 0) for descending range. 

As the name implies, a record type is a composite type consisting of a number 


of fields. For example, tvpe DATE could be defined as a record type as follows: 


type DATE is 
record 
DAY :SINTEGER range letowei, 
MONTH : MONTH_NAME; 
YEAR : INTEGER range 0 to 3000; 


end record; 


The tvpe MONTH_NAME would be an enumeration type consisting of the names of 
the months. 

As mentioned before, the variable in VHDL are strongly typed, and this means 
that the objects with different tvpes cannot be involved in the expression directly. An 


example is illustrated as follows: 
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-- declaration part 

Banal A: BYTE := "00001111"; 

suenal B : BIT_VECTOR(O to 7) := "11110000"; 
Seonal GC : BYTE; 

-- expression part 


C <= A and B; -- this expression will NOT be accepted by VHDL 


Although the A and the B all have eight bits, because they are different tvpes, the VHDL 
will not accept the expression shown in the above example. Note that in the declaration 
part, the signal A is assigned with an initial value via the symbol ”:=” immediately fol- 
lowing the type. 
4. CLASS OF OBJECTS 
In VHDL there are three classes of objects: constant, signals, and variables. 
a. Constants 


A constant 1s an object whose value may not be changed. Some examples 


of constant declarations are: 


constant PI : REAL :=3. 1416; 


constant MESSAGE : STRING(1 to 13) := "demonstration"; 


Note that each constant declaration must includes the name, the type, and the value of 
the constant. 
b. Variables 
Variables are objects whose values can be changed. When a variable is 
created by a declaration, a container for the object is created along with it. Variables 


are changed by executing a variable assignment statement; for example, 


Pee —— + C; 


Variable assignment statements have no time dimension associated with them, 1.e., their 
effect 1s felt immediately. Thus, variables have no direct hardware correspondence. But, 
they are useful in algorithmic representations. Some examples of the variable declara- 


tions are: 


variable FLAG : BOOLEAN := TRUE; 


variable COUNT : INTEGER := Q; 


The variable declarations specify the name, tvpe, and optionally an initialization value 
for the variable. Variables used in a process block are considered to be sratic; that 1s, the 
value of the variable 1s maintained by the simulator until it 1s changed by a variable as- 
signment statement. 
c. Signals 
Signals are objects whose values mav be changed, and the execution has a 
time dimension. Signal values are changed by signal assignment statements. The signal 
assignment statements are evaluated whenever one of the right hand elements of the 
Statements changed its value. An example 1s shown in Figure 12. Note that the signal 
assignment statement uses the ”“< =” symbol in order to differentiate it from the vari- 
able assignment statement. The “after Ons” in Figure 12 means that the “local” will take 
on its new value 10 ns later from the present simulation time. If the signal assignment 
statement has no after clause, then it 1s equivalent to “after Ons”. 
All the signal assignment statements in the same process level are concur- 
rently executed in the same simulation cvcle. Consequently, the positions of the signal 
assignment statements in the same process level are irrelevant. Thus, the signal assign- 


ment statements 1n Figure 12 can also be rewritten as 


d <= local and c; 


local <= a and b after 10 ns; 
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--Signal assignment statement 
local < = a and b after 10ns: 
d <= local and c; 





Figure 12. Signal assignment example 


One of the difference between variables and signals 1s that signals can have 
multiple queuing containers called drivers. The value of the signal is a function of all the 
related drivers. An example related to multiple drivers is shown in Figure 13. In the 
figure two signal assignment statements A and B assign values to the same signal X. 
For each signal assignment, a driver is created to hold the result of that assignment. In 
this example, drivers are labeled Dax and Dbx. The value of the signal X is determined 
by a resolution function F in this example. The resolution function F is user defined. It 
is activated whenever the drivers receive new values. The value of the signal is updated 
to the new value that coming from the resolution function. In Chapter III, the use of 


a resolution function to model the EP310 will be shown. 


Signal assignment A 


/ 


Function 7 


Signal 


/ 
a Drivers 
~ 
. 


Signal assignment B 


\ 
few 





Figure 13.  Mfultiple signal drivers and resolution function: [From Ref. 3] 


5. ATTRIBUTES 
An attribute defines and evaluates some characteristics of a named object. Some 
attributes are predefined and are related to types, ranges, values, signals, or functions 
[Ref-4: pp.4-14,15]. Signal attributes are particularly important in node Some 


predefined signal attributes are shown in the following examples: 


1. SEVENT returns a BOOLEAN value. If an event has occurred on 5 Gurimeaiie 
current simulation cycle the returned value is TRUE; otherwise, it returns the value 
FALSE: 


S‘STABLE(T) is of type BOOLEAN. It is TRUE if S has been stable for the last 
T time units. If T 1s zero, 1tisavritten as S$ SPABIEm 


tN 


S’DELAYED(T) is the value of S, T time units earlier. It has the same type as S. 


tas 


ty 
i) 


These attributes are useful in detecting signal changes and will be used in the later 
chapters. 
Another useful set of attributes are those associated with arrays. For example, 


suppose that an array variable was defined as follows: 


variable A : BIT_VECTOR (0 to 15); 


Table 1. ATTRIBUTE VALUES 
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Then, the set of attributes of variable A would have values indicated in Table 1. Many 
other useful attributes are defined in the "VHDL Language Reference Manual.” [Ref. 
4: pp. 14-1,9] 
6. SUBPROGRAM AND PACKAGES 
Subprograms define algorithms for computing values or exhibiting-certain be- 
havior. There are two forms of subprogram: procedures and functions. A procedure call 
is a Statement; a function call 1s an expression that returns a value. The definition of a 


Subprogram can be given in two parts: 
J]. A subprogram declaration defining its calling conventions. 


2. A subprogram body defining its execution. 


Packages, like subprogram, may be defined in two parts. A package declaration 
defines the visible contents of a package; a package body provides the hidden details. In 
particular, a package body contains the bodies of all subprograms declared in the pack- 


ave declaration. 


package Multiplication is 
type BIT ARRAY is (INTEGER range < > ) of BIT; 
function BitArray_Int (bits: BIT_ARRAY) .return NATURAL; 
function Int_to_BuitVec (int, length: NATURAL) return BIT ARRAY; 
procedure Obtain_Product (a,b: in BIT ARRAY; 
c: out BIT ARRAY; 
ov: out BIT); 
~----- other declarations 


eeewewrenaeawwwwewewwewewawva = 


end Multiplication; 


package body Multiplication is 
function BitArray_to_Int (bits: BIT ARRAY) return NATURAL is 
variable result: NATURAL := 0; 
begin 
for 1 in bits RANGE loop 
result := result 2: 
if bits) = ‘1° then 
result := result +1; 
end if: 
end loop; 
return result: 
end BitArray_to_Int; 


ese eueeerewzreeawveee eee ee ee awe BG eeeewerwreeeweoeeoe & 


procedure Obtain_Product( a.b: in BIT ARRAY; 
c: out BIT ARRAY; 
ov: out BIT) is 
variable local: INTEGER: 
constant limit: INTEGER:= 2 * a’ LENGTH: 
begin 
local:= BitArrav_to_Int(a) BitArrav_to_Int(b); 
if local > limuit-! then 
local := local mod hmuit; 


OVe= Le 
else 

ov:= 0: 
end if; 


c:=Int_to_BitArrav(local, a LENGTH); 
end Obtain Product; 


end Muluplication; 


Figure 14. Package example 
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Shown in Figure 14 is a package consisting of a type declaration and the inter- 
faces for two functions and a procedure. The code for the functions and the procedure 
are given in the package body. Ifa package contains no subprograms, a package body 
is not required. The package can be accessed by placing a use clause before the interface 
description of an entity. For example, if there is a entity called MULTIPLERS8 need to 
use the procedure Obtain_Product inside the Multiplication package in Figure 14. One 


could do this as follows: 


use WORK. Multiplication 
entity MULTIPLER8 is 
port (a,b: in BIT_ARRAY(0 to 7); 
prod: out BIT_ARRAY (0 to 7); 
Ouresout. Bid): 


end MULTIPLER8; 


architecture BEHAVIORAL of MULTIPLER8 is 
begin 
process (a,b) 
variable c: Multiplication. BIT_ARRAY (a’' RANGE); 
Wariaple. loc: BIT; 
bigin 
imlerp lication. Obtain Product (a,b,¢, loc); 
prod <= c after 100ns; 
ov <= loc after 100ns; 
end process; 


end BEHAVIORAL; 


Note that when the package feature is referred to by the statement inside entity 
“Multiplier8”, the package name must be placed in front of the package feature in order 
to establish “visibility” between those referred items and the entity. For example, the 
procedure “Obtain_Product” used in the enuty “MULTIPLERS8” must have the package 
name “Multiplication” in front of it. If the clause .all 1s added at the end of the use 
statement, 1.e., use WORK.Multiplication.all, then all the declarative items as well as any 
of its subprogram bodies contained in Multiplication package are “visible” within the 
entity MULTIPLERS. In this way, there is no need to repeat the package name in front 
of the referred package items. 

Packages are verv useful language features. Design groups can use group 
standard packages that contain the type declarations and subprograms related to their 
projects. As it will be seen in modeling the EPLD, a group standard package EPROM 
will be built and extensively used in the program. 

The VHDL language defines a package STANDARD that can be used by all 
entitues. This package contains the definitions for types BIT, BIT_VECTOR, 
BOOLEAN, INTEGER, REAL, CHARACTER YSTRING aie eas Vell as subtype 
POSIT E-and UA: | 

7. OPERATORS AND CONTROL STATEMENTS 

The operators and control statements of VHDL are similar to those of the other 

high level languages, especially Ada. A complete set of operators are shown in 


Fable 2. 


Table 2. VHDL OPERATORS 
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Table 3. VHDL CONTROL STATEMENTS 


LOOP | _RETURN 
NEXT _[__WAIT 
i. a 











The control statements of VHDL are shown in Table 3. Note that most of the 
Statements are verv general, and only reserved word wait need a further discussion. The 
Wait statement causes the suspension of a process or a procedure. In the real physical 
system, a process will frequently pause in its execution while waiting for a event to occur 
or a time period to elapse. Once the awaited event has occurred or the ume period has 
elapsed, execution of the process resumes. 


In VHDL the wait svntax is shown as follows: 
wWatteon senszlivity_jist until condition for tCime_out 


The statement suspends the process until a signal in the “sensitivitv_ list” changes, at 
which time the “condition” clause is evaluated. The “condition” clause is an expression 
Serpe BOOLEAN, Wi itis TRUE, the process resumes. Ihe time_out clause sets the 


maximum Wait time after which the process will resume. As an example: 


wait on x, y until (Z=0) for 100 ns; 


This statement will suspend a process until either “x” or “y” changes, then the expression 
"Z=0" is evaluated, and if the value is TRUE, the process will resume. The process will 
resume after 100 ns, even if the signals do not change or the condition is FALSE. 

Two major applications of the wait construct in modeling are the modeling of 


component interaction and oscillator behavior [Ref. 3: pp. 55]. The wait statement gives 


the designer additional freedom in writing high-level behavioral models. 


B. VHDL SUPPORTING ENVIRONMENT 

The purpose of having a VHDL supporting environment is to assist hardware de- 
signers in making efficient use of the capabilities of the VHDL language. A typical 
VHDL supporting environment includes the design hbrary, the Analyzer, and the Sim- 
ulator {Ref. 1]. Currently, there 1s only one VHDL supporting environment (Intermet- 
rics Standard IEEE 1076 VHDL Supporting Environment) installed at the Naval 
Postgraduate School. The following discussion will be based on this VHDL supporting 
environment. 

The Intermetrics Standard IEEE 1076 VHDL Supporting Environment consists of 
a Design Database and four software components as shown in Figure 15. A general de- 


scriptions of this VHDL supporting environment are listed as follows: 


1. Design Database. The Design Database is the central part of the system. The da- 
tabase of the hardware descriptions and related information are all stored in here. 


2. Analyzer. The Analyzer checks the hardware descriptions for syntactic and static 
semantic correctness. It also translates VHDL text to the Intermediate VHDL 
Attributed Notation (IVAN) form, and installs the translation into the Design 
Database. 


3. Simulator. The Simulator computes the behavior of a hardware model described 
in VHDL and thus provides a mean of checking dynamic semantic correctness. 
The Simulator constructs simulatable modules from IVAN data, executes these 
modules and generates reports on the runs. The Simulator consists of five sub- 
components [Ref. 5]. four of them are related to user and will be discussed as fol- 
lows: 
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a. Model Generator (MG). The Model Generator translates IVAN data into C 
source code, and compiles it to the simulation module. 


b. Build. Build links separately model-generated units and makes an executable 
Kernel in the Design Database. 


c. Sim. Sim invokes the Kernel and passes user-defined runtime parameters to the 
model. Execution of the simulation model will typically result in the production 
of a file containing signal history. 


d. Report Generator (RG). The Report Generator produces human readable re- 
ports from the file of signal histories. The selection of signals and the format 
of the report are determined bv report control language file supplied by the user. 


e. VHDL Library System (VLS). VLS provides the commands necessary for the 
Design Database. 


f. Design Library Manager. The Design Library Manager is the database man- 
agement system used by the Analyzer, Simulator, and VLS to access data in the 
Design Database. 


1 SIMULATION PROCEDURE 
After a VHDL model has been created, the model needs to be simulated. The 
simulation procedure is shown in Figure 16. The first step, as shown in Figure 16, 1s 
to invoke the Analyzer by typing the key word VHDL followed by the program file name 
as shown in the file Batch of Appendix D. If the model has no error, an IVAN form 


data will be created. Two rules govern how VHDL design units are analyzed: 
1. A body cannot be analvzed before its interface. 


2. A unit that references a package cannot be analyzed before that package. 


After the VHDL program has been translated to the IVAN form, it then can 
be sent to the Model Generator by tvping MG preceding the design VHDL unit name, 
l.e., the name of the entity or the package just been analyzed. If the VHDL unit is a 
package body, the qualifier ”/body” must follow the MG key word. 

Each model when simulated needs to have a top entity. This top entity may be 
thought of as a unit that contains a model under test. The top entity itself cannot have 
any ports, but, it can have generics for passing parameters from external entity or 


VHDL supporting environment. An example is shown in the TEST_BENCH of Ap- 
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VHDL fife-name 


MG [/body] {/top] design_unit_name 


BUILD [/replace] [/ker=kernel_name] top_entity-name 


SIM [/param] [/interactive] [/trace=select_file] [/map] kernel_name 


RG f[/map] kernel_name report_control_file 





Figure 16. Simulation procedure 


pendix B. In the structure of the top entity. the user must provide a test vector mech- 
anism in order to conduct the necessary testing. When generating this top entity, a 
qualifier “top” must follow the key word MG. 

After all the object modules have been “Model Generated”, they can be “linked” 
by tvping BUILD. This will produce an executable Kernel in the work library. The user 
can assign a kernel name by using the qualifier “’ker= name” following the kev word 


BUILD. 


The SIM key word will execute the Kernel and generate a Run in the working 
library. The SIM can be followed by a qualifier “/trace= select”, where “select” may be 
any file name which contains the pathnames of the selected signals. Consequently, the 
Simulator will record the histories of these selected signals. In this way, the user can 
discard those irrelevant internal signals, and use the limited memory to keep the wanted 
signal information. If no trace qualifier is specified, which is the default, then the his- 
tories of all the signals will be kept. 

As mentioned above, the top entity can only have the generic declaration, which 
can receive the values provided by the SIM qualifier ”/param=”. With this feature, the 
user can control the simulation time or even change the operation of the model. 

Besides the non-interrupting simulation mode, the VHDL supporting environ- 
ment also provides an interactive simulation mode as shown in Figure 15. In this mode, 
the user can set the breakpoint, see the signal transitions, and change the status of the 
signals. The interactive simulation mode is a verv useful tool in debugging. 

2, REPORT GENERATOR 

The Report Generator will produce a readable report file from recorded infor- 

mation. Its output signal and format are controlled by the report control file.. An ex- 


ample file is shown in Appendix B. The command to generate the report is as follows: 
RG control_file report_output_file 


Note that only those signals with histories preserved in the simulation can be generate 
im) there por: 

The qualifier ”/map” can be used with key word SIM and RG, this qualifier can 
produce a signal map, which contains all the signals used in the model. With this signal 
map, the user can easily find out the wanted signal pathnames. An signal map example 


is shown in Appendix C. 


3. WHDL LIBRARY SYSTEM (VLS) 
The VLS allows user to interact with the VHDL Design Database. The user can 
create his own library. A library is either a primary librarv or a secondary library. A 


primary library may contains the following kinds of data: 


¢e VHDL units, 1e., entity declarations, architecture bodies, package declarations, 
package bodies, configurations. 


e Simulation Kernel. 
e Simulation runs. 


® Other libraries. 


The secondary library may contain only package bodies, architecture bodies, 
and other secondary libraries. The purpose of secondary library is to allow users to 
experiment with their designs by using alternative package bodies or architecture bodies. 

The VHDL Library Svstem is entered by typing the VLS kev word. After en- 
tering the VLS, the user can make his own library by typing the key word MAKELIB 


followed by a physical library name, an example is shown below: 
MAKELIB <<user_account. EPROM>> 


Note that the symbol ”"< < >>” means that the name inside is the physical name of 
the created library. The user_account 1s the user login name. In VLS, this name is 
treated as a root library name. Every user must have a root library. In the example 
above, a librarv called EPROM was created under the root library. 

There are two predefined libraries: STD and WORK. STD 1s the logical name 
of the standard library. WORK is the logical name of the current user working librarv. 


The logical name can be declared as follows, 
DEFINE EPROM <<user_account. EPROM>> 
All the created VIIDL units will be stored in the current working library whose 


default 1s the root librarv. If the user wants to change the current working library, he 


oe 


or she has to tvpe the key word SETLIB followed by the physical or logical library name 


in the ¥ LS .environnient shor example 
SETLIB EPROM 


will change the working library to < <user_account.EPROM> >. 

The design group members may share each others libraries. For example, as- 
sume that there are two users, “phred” and “janus”. If “janus” creates a entity that uses 
the package EP310_PACK in the hbrary EPROM, and the EPROM belongs to “phred”, 


she may declare 


library EPROM; 


use EPROM. EP310_PACK. all; 


With the shared libraries, the user can avoid the redundant components and standardize 


the design. 


Il. MODELING THE EP310 


A. INTRODUCTION OF THE EP310 

The EP310 is an Erasable Programmable Logic Device (EPLD) manufactured by the 
Altera corporation. A user can use the CAE design tools, as shown in Figure 17, to 
configure the connections in the programmable AND logical array and the flexible 
output’ feedback section of an EP310. As shown in Figure 17, the user can do his design 
via schematic capture entry, state machine entry, netlist entry, or boolean equation 
entry. Once the design was finished, it can be processed, and a JEDEC file 1s produced. 
The JEDEC file is a file with the standard data transfer format from the design system 
to the hardware programmer unit. An EPLD can be physically configured by a “hard- 
Ware programer’ with the JEDEC file as input. 

Externally, the EP310 provides 10 dedicated inputs. One of which may be used as 
a synchronous clock input. Eight I’O pins, shown in Figure 18, may be configured for 
input, Output or bi-directional operation. 

Figure 18 shows the complete EP310 block diagram, and Figure 19 shows the basic 
EP310 macrocell. The internal architecture of a microcell is organized in a sum of pro- 
ducts (AND-OR) structure. Inputs to the programmable AND array, shown running 


vertically in Figure 19, come from two sources: 
1. The true and complement of the 10 dedicated input pins. 


2. The true and complement of 8 feedback signals, each one originating from a 1’O 
Architecture Control Block. 


The 36 input AND array, as shown running horizontally in Figure 19, is called the 
product term. There are 8 identical macrocells in an EP310. Each macrocell has 9 


product terms. Therefore, the total number of product term is 72. 
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Figure 19. EP310 macrocell [From Ref. 6 ] 


At cach poit of intersection in the product term, as shown in Figure 19, there exist 
an EPROM type programmable connection. Initially, all connections are made. This 
means that both the true and complement of the inputs are connected to each product 
term. Connections are opened, according to JEDEC Miesdirimicenn. hardware program- 
ming process. Therefore, any product term can be connected to the true or complement 
input signals. When both the true and the complement connections of anv input are left 
intact, a logical false results on the output of the product term. If both the true and 
complement connections of any input are programmed open, then a logical “don’t care” 
results for that input. If all inputs of a product term are programmed open, then a 
logical true results at the output of the product term. 

As shown in Figure 19, the outputs of 8 product terms are ORed together, and the 


output of the OR gate is fed as an input to the J]/O Architecture Control Block. [In the 


1/O Architecture Control] Block the signal from the OR gate is configured for register 
or combinatorial operation via Output Selection Switches. Both types of operations can 
produce inverted output. The feedback mode of the I/O Architecture Control Block can 
be programmed as combinatorial feedback, registered feedback, I/O (1.e, directly from 
the pin), or none, via the feedback selection switches. 

Besides the normal macrocell product terms, there are additional Synchronous Pre- 
set and Asynchronous Clear product terms. These product terms are connected to all 
D-type flip-flops. When the Synchronous Preset product term 1s asserted HIGH, the 
output of the register will be loaded with a HIGH on the next LOW to HIGH clock 
transition. When the Asynchronous Clear product term 1s asserted HIGH, the output 
of the register will immediately be loaded with a LOW independent of the clock. An 


asynchronous clear assertion overrides a synchronous preset asseration. 


B. DEFINE THE PROBLEM 

Since an EPLD device is programmable, its configured structure vanes with different 
implementations. It is desirable to model an EPLD device in VHDL so that it is inde- 
pendent to the design environment, 1.e, does not depend on the design tools. The model 
can read in a user created JEDEC file, and configure its internal connection to perform 
the user specified function. 

Besides the correct functional simulation, a model must also provide the correct 
timing simulation. When the timing of the model is violated due to register timing re- 
quirement, or bus collision, the simulator should be able to warn the user and report 


Where the error occurred. 


C. DECOMPOSITION OF THE EP310 
In this research, a hierarchical structure approach was used to model the EP310. 
The top of the hierarchy is the EP310 itself. Based on Figure 18, the components in the 


next level down in the hierarchy are the Logic Arrav Macrocell, 1}O Architecture Con- 


ae 


trol Block, and the tri-state buffer. Below the Logic Array Macrocell is the Product 
Term. Except for the tri-state buffer, all the other next level elements are declared as 
components in the EP310’s architectures as shown in Appendix A. The Logic Array 
Macrocell can be decomposed into 8 Product Term components. The I/O Architecture 
Control Block can be decomposed into the D-type flip-flop, the Output Select Unit, and 
the Feedback Select Unit as shown in Figure 19. Here, only a D flip-flop is constructed 
as a component below the I/O Architecture Control Block. The Feedback Select Unit 
and the Output Select Unit are implemented directly inside the I/O Architecture Control 
Block. 

Besides these 4 components, the EP310 model also need a place to keep the timing 
parameters and a function “READ _310” to read in the JEDEC file. All these EP310 
dependent functions and parameters were put into a package called EP310 PACK as 
shown in Figure 20. 

Functions to convert the types are needed whenever different type signals are passed 
between different entities. A resolution function to resolve the multiple-source signal 1s 
also required. Because of the general usability of these functions for all parts of the 
EPLD, these functions are put into a package called EPLD_ PACK, which 1s visible to 


all the necessary components as shown in Figure 20. 


D. ESTABLISH DATA FLOW 

After the hierarchy of an EP310 was established, it is necessary to reveal the signal 
flows between different components at different hierarchical levels. Externally, the 
EP310 chip can only see 18 data pins. Ten of them are input pins and the others are 
input, output pins. These 18 data pins are the data path between the outside circuit and 
the EP310 internal components. Beside these signals, an EP310 mode! must also receive 
a JEDEC file from the outside to simulate the designed behavior. This is done by 


passing JEDEC file data through a generic port to the simulated entity. 
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As discussed previously in this chapter, the Logic Array Macrocell has 36 signal 
lines which are derived from 18 data pins. In the VHDL model, instead of using 36 
signal lines, only 18 data lines were fed into the Logic Array Macrocell. These 18 data 
lines corresponding to the 18 data pins on the EP310. Doing it this way helps to reduce 
the excessive internal signals in the VHDL. The EP310 depending on the I/O architec- 
ture configuration can output signals through the input/output pins. 

The Logic Array Macrocell accepts 18 input signals and produce two internal 
signals. One is the tri-state buffer output enable, and the other is the ORed signal fed 
into the I’O Architecture Control Block. The Logic Array Macrocell must also receive 
the corresponding JEDEC file information, 1.e., 8 product term for each row of JEDEC 
file data. 

There are three input signals to the |]. O Architecture Control Block, one from the 
Logic Array Macrocell, one from the dedicated input pin (serve as synchronous clock), 
and the last one from the I’O pin. The | O Architecture Control Block outputs two 
signals, one 1s the feedback signal, and the other is fed into the tri-state buffer. The ],O 
Architecture Control Block must also receive the corresponding JEDEC file information 
that used in configuring the switches in the two select units. 

For a D flip-flop there are four input signals. One 1s the clock which is from the 
dedicated synchronous clock input pin. The second one is the synchronous preset which 
is from the synchronous preset product term. The last one is the asynchronous clear 
Which is from the asynchronous clear product term. Although, there are no program- 
mable connections in the D flip-flop. the JEDEC file informations 1s still needed to dis- 
able the assertion mechanics inside the D flip-flop. which will be discussed in the 
PeGISTER TIMING section: 

The Product Term was used inside the Logic Array Macrocell and the EP310. The 


Product Term has 18 inputs signals passed from the next higher hierarchy level and 
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Figure 20. Decomposed EP310 hierarchical block diagram 


produce one output signal. The Product Term must also receive the JEDEC file infor- 
mation from the next higher level entity in order to perform the user specified functions. 

Figure 20 shows the decomposed hierarchical block diagram. As discussed above, 
the EP310 consists of 4 components, Logic Array Macrocell abbreviated as Macrocell, 
1;O Control Architecture Control Block abbreviated as IO control, Product Term ab- 
breviated as P_term, and D flip-flop abbreviated as D_register. 

The binding of component to entities is performed by configuration specifications. 
The configuration performs a component selection kind of function. With this feature, 
interchange of components from different technologies are possible. -As iS eERES: in 
Chapter II], VHDL configuration specifications appear in the declarative part of the 
block where the corresponding component are called. In certain cases, however, it may 
be more suitable to leave the configuration unspecified and defer such decision until the 


Kernel is built [Ref. 4: pp.1-9]. 


E. SIGNAL ASSIGNMENT 

There are two ways to assign signals. One is to gather signals with common prop- 
erties In an array. The other is to treat the signals separately. The benefit of using a 
signal array is its simplicity. But, there is a drawback. That is, each time when one of 
the elements 1n the arrav is activated, the whole array is activated. The processes asso- 
ciated with the elements of the array will be activated too often in a complex design. 
This costs a lot of simulation trme. On the contrary, the single signal assignment may 
be more efficient 1n reducing the simulation time. But, it will make the model complex 
and hard to comprehend. In this study, the EP310 data pin signals are defined sepa- 
rately in order to reflect the real chip pinout; the rest of the signals are implemented bv 


using the signal arrav. 
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F. JEDEC FILE INFORMATION TRANSFER 
As mentioned before, the EPLD model needs to read in the JEDEC file information 
in order to perform the designed function. There are three methods to transfer the 


JEDEC file information from outside to an entity model: 
1. Assign information via generic. 
2. Passing information via port. 


3. Passing information by predefining it as a constant in the package, and make it 
visible to the entities. 


Since the JEDEC file depends on the user’s implementation, it can vary. It 1s not 
a good approach to declare the JEDEC file data as constants inside the package. If 
signals were used to transmit the JEDEC file data, the total number of signals including 
the implicit signals will be too large. This will affect the total simulation time, since ev- 
erv signal driver of this large set has to be checked at each delta cycle. 

Due to the reasons discussed above and the nature of the JEDEC file, passing in- 
formation via the generic is preferred. In this research, using generic to transfer JEDEC 
file information were adopted. The JEDEC file name is fed in via the EP310 generic at 
one level higher than the EP310 entity. In the EP310 declaration part a function called 
READ JEDEC is used to read in the necessary JEDEC information. An example of 
using generics to pass the JEDEC file data to EP310 entity is illustrated on the next 


page. 
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-- inside package EP310_PACK declaration. 
function READ_JEDE(file_name: in string) 


return jedec_file_data; 


-- inside the TEST_BENCH body. 
architecture demo of test_bench is 
component EP310 generic(JEDEC_file_ name); 
port(pinout_specification); 
-- other statement. 
begin 
EP310 generic map(user_defined_JEDEC_file) 
port map(pinout_specification); 


-- other statement. 


end 


-- inside the EP310 entity body 
architecture STRUCTURAL of EP310 is 
constant BIT_MAP : jedec_file_data 


s= READ JEDEC("JEDEC_file_ name’); 


The constant “BIT_MAP” is declared to have a “jedec_ file data” type, and its value is 


assigned by the returned value from the function READ JEDEC. After the BIT. MAP 


is initialized, its subcomponents are passed via generics to the corresponding compo- 
nents below the EP310. Note that the “jedec_file_ data” type is not defined here. Refer 


to Appendix A for the actual declaration and the exact program. 


G. MULTIPLE LEVEL LOGIC 
Because not all pins on the chip will be used, it is necessary to introduce a signal 
with three-level logic to represent the unconnected situation. The EP310 model uses a 


new tvpe TRI, which as shown below has a three level logic: ‘0’, I’ and ’U’. 
type: TRI“is*( Us Gaps: 


The ‘U’, depending on the location of the signal, means unconnect or undefined. 

Since the VHDL 1s a strongly typed language, when constructing a multiple state 
design, it is necessary to include a type conversion function to pass different type signals 
between different processes. The following is a conversion function example used in the 


EP310 model. 


function” tri /fowbitClinbit: trigmreturne pit. is 
begin 
if inbit= 1" then 
Eeturn: dee 
else 
return '0'; 
end if 


end Dit tomtai. 


Note that, the conversion function will return a value ‘0’, if the input is “U’. 
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eee USSED SIGNAL 
Shown in Figure 21 is an example where the signal “local” is driven by two sources. 
’ The sources of the signal “local” can come from the output of the tri-state buffer or from 


the “10_pin”. Below 1s the statement that can model this connection. ; 


local<= output after tod when enable='1' else 


tompin after tiottin; --tiottin is input delay 


OE (output enable) 


signal from 


Output select unit 


"local" input 
to feedback select unit 





Figure 21. 1/O primitive signal flow diagram 


Note that the statement above has implied that the “output” signal has higher pri- 
ority then the “io_pin” signal. This is reasonable, since the “output” signal drives not 
only the “local” signal but also the “io pin” signal. Only when the tri-state buffer is 


disabled, will the “1o_pin” signal value be assigned to the signal “local”. 
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As mentioned before, the “io_pin” 1s a bi-directional pin driven by two sources, one 
is the tri-state buffer output, and the other is an external user input. It is driven in a 
time multiplexing sense. In order to model this circuit, it is necessary to declare the 
“10_pin” signal as a resolved signal. A resolved signal is a signal that has an associated 
resolution function. Resolution function is a user defined function that computes the 
value of a resolved signal form its multiple sources. 

There are two ways to declare a resolved signal. One is by adding a resolution 


function to the front of the tvpe, such as: 


Signal io_pin: inout RESOLVER tri; 


The other way is to declare the signal with a resolved subtype, such as: 


subtype tri_state is RESOLVER tri; 


Signal io_pin: tri_state; 


The resolution function used here is called the RESOLVER. Basically, the RE- 
SOLVER will gather all the sources of the declared signal, compute it according to user 
defined rules, then return the resolved value. Below is the implementation of the func- 


tion RESOIERY 1k. 


function RESOLVER(signal inputs: tri_vector) 
return tri_state is 
t 


variable resolved_value: tri_state:='U'; 


variable flag: integer:='0'; 
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begin 
for i in inputs'range loop 
if inputs(i)/='U' then 
tlace—“flag + 1; 
resolved_value:= inputs(i); 
end if; 
end loop; 
assert flag <= 1 
report "io_pin bus collision." 
severity FAILURE; 


return resolved_value; 


end RESOLVER; 
In the signal assignment statement the 10_pin 1s assigned as: 


io_pin <= output after tod when oe = '1’' else 
'U' after tod when oe= '0' else 


t t 
Lo Nae 


Note that if the corresponding tri-state buffer is enabled, i.e., oe= ‘1’ an in aie mean- 
time, the user gives 10_pin another assignment from the top entity, then the signal will 
have two active sources. It means that the source values are not all ‘U’. In this case, 
the resolution function shown above will assert the data collision message. On the other 
hand, if only one source is active, the resolution function will output the active source 


value and assign it to the 10_pin without the violation message. 


I. PRODUCT TERM INTERNAL CONNECTION 
As mentioned previously the EPLD logic array has programmable internal con- 


nections. The connections were made according to the corresponding JEDEC file spec- 
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ification. In this research a function, called check_Pterm, is used to generate the correct 


functional output. The check Pterm function has two type of inputs: 
1. Eighteen signals from the feedback lines shown in Figure 19. 


2. Thirty-six internal connection specification defined as P_ string from the JEDEC 
fle: 


The check_Pterm function generates the correct value according to the specification and 
the conventional logic array rules discussed in the previous section. The main mech- 
anism of this function is to decide whether the input signal should be included by ex- 
amining the true and complement connections of the signal in the JEDEC file. Shown 
below is a portion of the decision statements used in the check _Pterm. The statemens 
are written in VHDL alike pseudo code. Refer to the package EPLD_ PACK of Ap- 


pendix A for the full exact detail: 


-- begining of the decision statement. 
output:='1'; 
1: =1; 
while i<=P_string' length loop 
if(P_string(2*i-1)='0' and P_string(2*i)='1') and 


(input_signal(i)='U' or input_signal(i)='1') then 


output: ='0' 

exit; 

end if 

-- other decision statements. 
end loop; 


return output; 


The “P_ string” in the above example is an array which contains the programmable 


AND array internal connection data. The statement “P_string (2*1-1)=’0° and 
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P_string(2*i)= ‘1’ ” will check the connections to see whether only the complemented 
connecting point shown as P_string(2*i-1) exists. If the complemented connecting point 
exists and if the corresponding “input_signal(i)” 1s ‘1’ or “U’ (unconnected), the output 
will be ‘0’. With statements similar to the above example, the other three situations are 
checked to produce the correct output. These three situations are: a) both the true and 
the complement connecting points exists, b) both points do not exists, or c) only the true 


connecting point exists. See the function check_Pterm of Appendix A for the details. 


J. EPLD TIMING SIMULATION 

As discussed in a “EPLD timing simulation” paper [Ref. 7], the timing diagram of a 
general EP310 is shown in Figure 22. The delay time through logic array (tlad) was 
modeled as a constant. The rest of the timing parameters were like those found ‘a the 


conventional logic circuit. Below are the description of the timing parameters shown in 
ficure 22. 
]. tin- input pad and buffer delav. 


2. tio- | O input pad delay. This delay need to be added to tin when an [/O pin 1s used 
as input. 


tod- output buffer and pad delay. 
txz- time to tri-state output delay. 
tzx- tri-state to active output delay. 
tlad- logic array delay. 

tlade- enhanced logic arrav delav. 


tsu- register setup time. 


oO NDA Bw 


th- register hold time. 


10. telr- asynchronous register clear time. 


l 


= 


. telre- enhanced asvnchronous register clear time. 
i tics- svstem clock delay. 

13. tic- clock delay. 

14. tice- enhanced clock delay. 


. tfd- feedback delav. 


— 
Cn 


5] 


IHPUT SYSTEM CLOCK DELAY tics »| REGISTER 


DELAY j_,__, CLOCK DELAY 
at | tic 3=—_ tice 


—» LOGIC ARRAY DELAY 





a FEEDBACK 
Lieu , DELAY 
tro 





Figure 22. EPLD timing block diagram [From Ref. 7 ] 


16. tch- minimum clock duration, when clock is high. 


17. tel- minimum clock duration, when clock 1s low. 


Since a EP310 is decomposed into four components shown in Figure 20, it is nec- 
essary to assign cach component with its associated tinung parameter. Figure 23 shows 
the decomposed components with their timing parameters. All the timing parameters 
used i this research can be found in [Ref. 7]. 

1. REGISTER TIMING 
The most important timing problem related to a register is its setup time, hold 
time, and minimum pulse width. For example, consider the clocked register in 
igure 24. Jt is a common requirement that the data input be stable for a duration of 
time prior to the clock transition that strobes the data into the register. This require- 


ment is known as the setup ume of the data relative to the clock. A similar requirement 
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Figure 23. EP310 hierarchical block diagram with time parameter 


states that the data should remain stable a minimum amount of time after the clock 
transition which is known as the hold time requirement. 

Figure 24 shows the input specifications for the register in a typical EPLD. The 
specification savs that (1) DATA should be stable for tsu nanoseconds before CLOCK 


rises, (2) DATA should be stable for th nanoseconds after CLOCK rises, and (3) 
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Figure 24. D register timing diagram 


CLOCK should have a minimum duration at the high level of at least tch nanoseconds. 
The following assertion statement in VHDL checks the setup time specification of the 


D register of the EP310: 


assert not( not clk'stable and clk='1' and (not d'stable(tsu)) and 
clear='0' and (03='0' or 04='0' or F2='0')) 


report "Setup Time Failure’; 


Using the DeMorgan’s theorem, one could convert the assertion statement to a simpler 


form 


assert ck'stable or ck='0' or d'stable(tsu) or clear='1' or 


(@e= 1 wand O4= 1° and F2='1') 


In the above example the attribute D'STABLE(tsu) will be TRUE if and only 
if signal D has been stable for tsu time units already. Since this D register has an 
asynchronous clear, it 1s necessary to include “clear= 0” in the assertion statement. 
Otherwise, when the “clear” is set to one, the D register will resume the synchronous 
clock cycle and produce the errorous result. The reason for checking the switches O3, 
O4, and F2 in Figure 19 1s to see if the register is selected to operate. If the macrocell 


is dedicated to perform combinational logic, then the assertion will be disabled. 
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Figure 25. fold tine timing diagram 


The hold time can be checked by using the following VHDL statement: 


assert ck'delayed(th)'stable or ck'delayed(th)='0' or d'stable(th) or 
clear='1' or (03='1' and O04='1' and F2='1') 


report "Hold Time Failure’; 


The statement will check the stability of data “d” after the necessary hold time (th). The 
hold time start from the rising edge of the clock and end at the falling of the clock as 
shown in Figure 25. If the evaluation of the statement are false then the error will be 


reported, which means the flip-flop hold time is not satisfied. 


Similarly, the minimum pulse-width can be checked by using the following 


statement: 


assert ck'stable or ck='1' or ck'delayed'stable(tch) or (03='1' and 04='1' 
and F2='1") 


report "Minimum pulse width failure’; 


K. COUNTER 

An EP310 was configured to implement a 7-bit counter. The JEDEC file was gen- 
erated by using the Altera logic design tool. The model was tested as a 7-bit counter. 
The simulation starts from a top entity called the "TEST BENCH”. The code of the 
“TEST_BENCH” and its architecture body are shown in Appendix B. The simulation 
result are also shown in Appendix B. Basically, the “TEST BENCH” calls the EP310 
entity, provides the signals to the EP310’s input pins, and the the external JEDEC file 
name to the EP310’s generic. The user can control the simulation time via the generic 


mee TEST BENCH”. 
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IV. MODELING THE EP1800 


A. INTRODUCTION OF THE EP1800 

The EP1800 like the EP310 discussed in Chapter III is also an Erasable Program- 
mable Logic Device with a larger number of macrocells. In the EP310 there are about 
300 gates, but in the EP1800 there are about 2100 gates [Ref. 6: pp. 2-4]. The EP1800 
has a classic programmable AND array just like the EP310. But, unlike the EP310 
Which has only one D-type flip-flop, the register inside the EP 1800 can be programmed 
into a D-tvpe, T-type, JK type, or RS tvpe flip-flop. Each register can be clocked 
asynchronously on an individual basis or synchronously on a banked register basis [Ref. 
6: pp. 2-6]. 

The block diagram of an EP1800 is shown in Figure 26. Externally, the EP1800 
provides sixteen dedicated data inputs, four of which may be used as the system clock 
inputs. There are 48 1/O pins which can be individually configured to be input, output, 
or bi-directional pins. 

Internally, the EP1800 contains 48 macrocells. As shown in Figure 27 and 
Figure 28, each macrocell contains three basic elements: a logic array, a selectable reg- 
ister element, and a tri-state 1.O buffer. All the combinatorial logics are implemented 
within the logic array. For register applications each macrocell provides one of four 
possible flip-flop operations: D, T, JK, and SR. 

The EP1800 is partitioned into four identical quadrants as shown in Figure 26. 
Each quadrant contains 12 macrocells. The macrocell input signals come from the 
EP1800 internal bus structure. The macrocell output may drive the EP1800 external 
pins as well as the internal buses. Sixteen of the EP1800’s 48 macrocells offer increased 


ae 


speed performance through the Logic Array. These “Enhanced Macrocell” can be uti- 


58 


QUADRANT A 















2 (FY 

vO Ro - 77 MACROCELL 17°74 
3 1G2} 

vo 5-2 (4) MACROCEUL 2 >»: 
4¢G1} — 

vo fo 5.3) MACROCELL 3 049 5. 
5 (42) 

vo Kou "> MACROCELL 4..." -, 
6 iH)} . 

vo Koa MACROCELL 5 
7 4.12) 


LOCAL BUS—OQUADRANT A 





MACROCELL 11 
vo f3-74 MACROCELL 12 


4 


13 (13) 





14 (KA) 
INPUT 

19 1L 4} e 
INPUT [_) ie 


UP | L 
INPUT/CLK 1 CC) 


19 (LA) 
INPUT/CLK2 

<0 tK7) n 
INPUT [)}— &. 

21 (L7y 
INPUT C) 

2 KB} 
INnNFUT [_) 









23 (U8) 
[a | 


MACROCELL 13 
yo tet nacnoceite 
aces MACROCELL 15 


MACROCELL 16 





75 (L410) 
vo f= 












vo ; MACROCELL 17 
28 (KAVA 


vo 3 — MACROCELL 18 
29: (510) 

MACROCELL 19 

MACROCELL 20 


tk’ ,MACKROCELL 21 46 


ae &.-" MACROCELL 22° 
C—] i MACROCELL 23°: 
Se) 'MACROCELL 24 3.. 


QUADRANT B 









LOCAL BUS—OQUAORANT 8 


18 (K6) 
vec ()}— 


1 (F2) 
GNO 


{ — 4- RESTA FOO FI PG PACK SE 





Figure 26, 


GLOBAL 8US 


LOCAL BUS—OUAORANT O 





QUADRANT D 


(ear && 
> INPUT 
{ASt 32 
eS a CS inPut 
(BS) Ss 
ae. eae < ' 
a (25. 2 
Sa SS eae 


(a areata a ooraemameede il {BT} “o 

@i INPUT 
(AB <3 

(oe ee eco. 3 (J iNPUT 

ae (RAL 28 

nit. a < INPUT 


LOCAL BUS—OQUAORANT C 








| mcnocee 1S 

naa 111) £3 
C*1: 42 

wo 


C101 a? 


eo 
— MACROCELL 29 : 
-— 


5) 
af{]s 
3 


Soe MACAOCELL 25 23 


QUADRANT C 





(86) S2 
vec 


(F10} 35 
——(_ GNO 
(_] GENERAL MACROCELLS 
[_] aiosat MACROCELLS 
(CJ ENHANCED MACROCELLS 


EP1SO0 block diagram [From Ref. 6 ] 


OUA DRANT 
TT NCrRONDUS 
CLOCK 


OR/CLOCK 
ee GLOBAL BUS 


® 
1 
2 
3 
4 
$ 
6 
? 


OLOBAL QUADRANT 
DE OICATED LOCAL 


FEE OBACK 
(12 MACROCLLLS) 





Figure 27. Local macrocell: [From Ref. 6] 


lized in places where combinatonial logic path delay is critical. There are four Enhanced 
Macrocells for each EP!1800 quadrant as shown in Figure 26. A detailed delay timing 
specification of these Enhanced Macrocells are listed in the file EP1800 PACK in Ap- 
pendix A. 

There are other sixteen “Global Macrocells” that can provide dual functions. These 
Global Macrocells shown in Figure 28 implement buried logic functions, and at the same 
time serve as dedicated input pins. Thus, the EP1800 may have an additional 16 input 
pins vielding a total of 32 inputs. The Global Macrocells have the same timing charac- 
teristics as the General Macrocells (Ref. 6: pp. 2-7]. 

Each of the EP1S800 internal flip-flops can be clocked independently or in user- 
defined groups. Any input or internal logic function may be used as a clock. These 


clock signals are activated by driving the flip-flop clock input with a clock buffer primi- 
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Figure 28. Global macrocell: [From Ref. 6] 


tive (CLKB). In this way, the flip-flop can be configured for either positive or negative 
edge triggered operations. 

Four dedicated system clocks, CLK1 through CLK4, provide clock signals to all the 
flip-flops. Svstein clocks are fed directly from the EP1800 external pins. With this direct 
connection, a systein clock imposes the shortest delay than internally generated clock 
signals. There is one system clock per EP1800 quadrant. When using system clocks, the 
flip-flops are positive edge triggered, 1.c., data transitions occur on the rising edge of thie 


clock. 


B. DECOMPOSITION OF THE EPI800 
Just like the EP310, the hierarchical structure approach is used to decompose thie 
EP1800. The top level is the EP1800 itself Based on Figure 26 the next level down in 


the hierarchy are the Quadrants. Below this level 1s the Global Macrocell and the Local 
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Macrocell. The hierarchical levels lower than macrocells are similar to those structures 
Mice deed e: 

The EP1800 model also needs a function READ JEDEC to accept the JEDEC file 
and a few other necessary functions to implement the real physical device. All these 
functions together with the timing parameters and the defined types are stored in a 
package called EP1800_PACK as shown in Figure 29. 

The EP1800_PACK and the EPLD packages discussed in Chapter III are visible to 
all the necessary components. The total EP1800 hierarchical structure is illustrated in 


rouiremc. 


C. ESTABLISH DATA FLOW OF THE MODEL 

After the hierarchy of the EP1800 is established, it 1s necessary to identify the signal 
flows between different components. 

Looking at an EP1800 chip from outside, only 60 data pins and 4 dedicated svstem 
clock pins are visible as shown in Figure 30. Therefore, at the top level of the entity 
EP1800, there are 64 signals in its port declaration. These 64 signals serve as the signal 
paths between outside circuit and the EP1800 internal components. Besides these 
signals, an EP1800 model must also receive a JEDEC file from the ouieae to simulate 
the user-designed behavior. This is done by passing the JEDEC file name through a 
generic port to the simulated entity just like the method used for EP310. 

Inside the EP1800 entity, there are 4 quadrants. These 4 quadrants are symmetric 
in some sense, 1.e., two of them are upside down. Therefore, there is only need to build 
one quadrant model. The remaining quadrants can be implemented by using the model 
directly or modifving the generic with the reverse function. The details are described in 


the EP1800 architecture body of Appendix A. 
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Figure 29. EP1800 hierarchical model diagram 
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Figure 30. EP1800 chip overview: [From Ref. 6] 


The signals going into each Quadrant include the global bus inputs and a system 
clock input. Four of the Quadrant output signals are from the Global Macrocell tri- 
state buffer outputs. The rest of the 8 signals are bi-directional General Macrocell I/O 
pins. 

There are 12 macrocells inside each Quadrant. These macrocells a elassitiee as 
Global Macrocell, General Macrocell, and Enhanced Macrocell. The structure of the 
General Macrocell is the same as the Enhanced Macrocell. The only difference between 
these two macrocells 6 Te the Enhanced Macrocell has a shorter time delay. There- 
fore, When modeling the EP1800, it is only necessary to build the General Macrocell 
modules and the Global Macrocell module. The Enhanced Macrocell module can be 
yielded by changing the timing parameters of the General Macrocell. 

The macrocell accepts bus inputs and a system clock input. The bus inputs consist 


of 44 input signals. The macrocell outputs consists of two signals. One comes from the 
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I/O Architecture, and the other is a tri-state output enable signal. The internal struc- 
tures of the Global Macrocell and the General Macrocell are identical except that the 
General Macrocell has a feedback select switch and the Global Macrocell has an output 
enable switch. The total numbers of signal-flow control switches are the same in both 
type of macrocells. 

The I/O architecture in the macrocell accepts the ORed logic array signal, an input 
clock signal, and a register clear signal. The ORed logic array signal is generated from 
8 ORed logic-and-arrays similar to those in the EP31!0 structure. The input clock signal, 
depending on the clock select switch, is either from the quadrant synchronous clock or 
from the enable‘clock logic-and-array output. 

The internal structure of the I/O architecture consists of a D-type flip-flop, logic 
gates, and 3 signal flow control switches. Because of the manecieclaaie aggreement with 
the Altera corporation, the detail structure inside the I/O architecture is not discussed. 
In Appendix A, the I'O architecture module of the EP1800 only shows the entity dec- 
laration part.! 

All the EP1800 internal connecting point information in the JEDEC file are passed 
to the entity via the corresponding entity generic. The parameter in the generic of 
EP1800 is a character string which can be any user-created JEDEC file name. After the 
JEDEC file name is passed into the body of the EP1800, the function READ_JEDEC 
will read in the JEDEC file data stored in the JEDEC file name. The function will assign 
this composite tvpe (EPI800 TYPE) JEDEC file data to a constant call BIT_MAP. 
Then, lke that done for the EP310, the corresponding elements of this composite con- 
stant are passed to the corresponding lower level components. For more details please 


see Appendix A. 


1 For more information please contact Prof. CHIN-HWA LEE, Naval Postgraduate School, 
Monterey, CA 93943. 


D. GENERAL MACROCELL AND ENHANCED MACROCELL 

As mentioned previously, the General Macrocell and the Enhanced Macrocell have 
the same structure but different timing parameters. In order to make the model size 
more compact and to avoid the redundant VHDL program, these two types of macro- 
cells use the same architecture body. The way to define whether the macrocell is a 
General Macrocell or an Enhanced Macrocell is by passing different timing parameters 


via generic. For Enhanced Macrocell this would look like: 


ENHANCED: LOCAL_MACROCELL generic map(P_ARRAY(1 to 10), 


IO_ARRAY( 1), tlade, tclre, tic) 


where the “tlade”, “tclre’, and “tic” are the enhanced timing parameters. The 
"P_ ARRAY” and the “IO ARRAY” are array types. They contain the corresponding 
product terms and 1/O select unit JEDEC file data. The word “enhanced:” in front of 
the local _macrocell is referred to as the label of this component instantiation. If there 
are more than one identical component instantiation in the same block level, the labels 
with different names must be used in front of these instantiations. The General 
Macrocell and Enhanced Macrocell have the same expression but different generic val- 


ues, 1.e., the timing parameters. 


FE. THE REUSABLE QUADRANT MODEL 

Although the Quadrants inside the EP1800 have the same structure, the pin assign- 
ment combined with the ordered JEDEC file data makes the generic map assignment of 
Quadrant-B and Quadrant-C in the reverse order. In order to reuse the same Quadrant 
model, in this work, two “reverse functions” are built. Both “reverse functions” can re- 
verse the order of the input array. Below is one of the reverse function used in the 


EP1800 model. 
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function REVERSE(A: in IlO_array_type) return I0 
_array_type is 
variable rev_array: IO_array_type( 1 to A' length); 
variable c: POSITIVE := 1; 
begin 
for i in A'REVERSE_RANGE loop 
rev_array(c):= A(i); 
Cie C+l: 
end loop; 
return rev_array; 


end REVERSE; 


Note that the attribute “A°’REVERSE RANGE’ will output the A’s range in the reverse 
order. That 1s, the attribute will have the range A’RIGHT downto A’LEFT if the range 
of A is ascending, or A’RIGHT to A’LEFT if the range of A is descending. These two 
reverse functions are put into the package EPI800_PACK. 

When using the Quadrant B and C, the reverse function 1s placed in front of the 


generic parameter P_array, and IO_array as follows 


QUADRANT_B: 
QUADRANT generic map(REVERSE(P_array(range)), 
REVERSE( I0O_array( range) )) 


-- port map specification 


Note that the variables inside the above two REVERSE functions have different tvpes. 


In spite of the different tvpes of this two arrays, the VHDL will automatically find the 


| 
| 
| 
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corresponding matching function according to the input parameter tvpe. In VHDL this 


kind of functions are called overload functions. 


F. THE EP1800 BUS STRUCTURE 

The internal bus structure of the EP1800 1s more complicate than that of the EP310. 
Basically the EP1800 bus can be divided into two kinds, local bus and global bus. The 
local bus, as the name implies, only provides a signal path between macrocells within the 
same quadrant. The Global bus on the other hand provide the signal path to all the 
macrocells inside the EP1800 chip. 

The local bus consists of 12 feedback signals from 12 macrocells as shown in 
Figure 27 and Figure 28. These local feedback signals can only feed into the macrocells 
of that quadrants and cannot be accessed bv the other quadrants. The local bus has two 
kinds, one is from the Global Macrocell I1‘O Architecture output, and the other is from 
the Local Macrocell feedback. The local bus from the Local Macrocell feedback has two 
sources, one is from the I,O Architecture output and the other is from the I/O pin. 
Which one of the two sources to use 1s decided by the feedback select switch as shown 
in Figure 27. This switch 1s configured by the JEDEC file data. 

The global bus can be divided into two classes, one 1s for the Global. Macrocell 
feedbacks and the other is for global dedicated input pins. The Global Macrocell feed- 
backs come from each quadrant’s 4 Global Macrocells as shown in Figure 26. Since 
there are four quadrants, the total global feedbacks are 16. The global bus can be ac- 
cessed by any macrocells within the EP1800. 

The EP1800 bus signal assignments are done at two entity levels. The global bus 
signals are assigned at the EP1800 entity level as shown in the EP1800 architecture body 
of Appendix A. The local bus signals are assigned at the Quadrant entitv level as shown 
in the Quadrant architecture body of Appendix A. The global bus and local bus are 


concatenated together at the Quadrant enuty level as follows 
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inputs <= local_bus & global_bus; 


where the symbol “&” means concatenation. Here, this statement will connect the sec- 
ond array “global_bus” right after the first array, and form a new array “inputs”. This 


new array will be fed to the macrocells. 


G. UP-DOWN COUNTER 

An application simulation of the EP1800 model was done in this study. The model 
was implemented as a 16 bits up/down counter. The counter was constructed by cas- 
cading two §-bit counters together. The 8-bit counter used here was adopted from the 
ALTERA’s TTL Macrofunction library [Ref. 8]. Figure 31 shows the 16-bit up-down 
counter block diagram and its corresponding function table. 

The simulation was done by running a top entity discussed in Chapter II called the 
SeestebeE NCH. the code of the TEST BENCH’ and the corresponding result are 
in Appendix B. Basically, the “TEST BENCH” will call the EP1800 chip and provide 
the signals and the external JEDEC file name via the port map and the generic map to 
the EP1I800. The JEDEC file can be created by any EPLD development tool as dis- 


@essed in Chapter III. 
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V. CONCLUSIONS 


A. GENERAL 

In this thesis the general VHDL language features were introduced first. Then, the 
discussion of the EP310 and EP1800 structures leads to the modeling of these devices. ' 
Study revealed a number of problems in modeling these EPLDs. The solution of these 
problems were described and tested. The modeling technique used for EP310 and 
EP1800 can be equally applied to the modeling of other types of EPLD with similar 
structure. | 

It is verv difficult to verify the model’s accuracy. One way to verify the accuracy 
of the model is by running the manufacture’s hardware test vectors for the corresponding 
hardware [Ref. 9]. Since the manufacture’s test vector is not available , in this study only 
the correctness of the individal modules are tested. If all the modules can work accu- 
rately, the whole model can also work accurately. 

The EP1800 and the EP1810 have a similar structure. The only difference between 
them is that the general macrocells in an EP1800 were replaced by the Enhanced 
Macrocells in the EP1§10.. The model of EP1800 with different timing parameters can 
also be used as the EP1$10 model. 

After using the VHDL to model the EPLD hardware, there are a few comments 


about the VHDL language: 


1. The VHDL language is powerful. The VHDL has a verv rich instruction set, and 
it also has the timing features in it. This makes the VHDL not only a very good 
hardware description language but also a very powerful simulation language. 


2. The VHDL 1s verv flexible. The language allows the users to declare their own 
object types and signal attributes, which makes the modeling easier. 


3. The VHDL language can describe the hardware from three different views: behav- 
ioral, data-flow, and structural. The first two views lets the user model the hard- 
Ware at an abstraction level. The hardware physical description is done at the 
Stagicture lexel. 


1) 


4. A hardware description can be detailed and accurate. The control statement and 
timing facilitv discussed in Chapter I] allows the model to reflect not only the 
function of the hardware but also the timing characteristics. 


5. The VHDL language statement is easy to comprehend. Since the VHDL is ori- 
ginallv used as a description language, it allows meaningful variable and signal 
declarations. It also allows modules to be declared as functions. This make the 
program code more readable than most of the other languages. 


6. The VHDL language learning curve is longer than those of the other languages. 
As was discussed before, the VHDL has a verv rich instruction set. This sometimes 
is not a merit to the user, since rich instruction set means user need to take a longer 
time to learn more language features and rules. 


B. PROGRAM SPEED 

Like the other hardware simulation, the VHDL simulation takes a lot of time. In 
VHDL each simulation cycle 1s called a delta cycle. The simulation is event-driven, 
which means whenever any signal changes its value, the simulator will execute the cor- 
responding statements once. If the model is too complicated or contains too many de- 
tails which used up more internal signals, it will costs a lot of the CPU time. On the 
other hand, if the model is very abstract, 1.e., modeling at the chip level or system level, 
then the simulation time can be reduced considerably. 

The models built in this study are gate level models which contain a detailed circuit 
description. This means that the models built here need more execution time than the 
other approaches. Besides long simulation time, model analvzing, generating and 
building processes also takes longer time than anticipated. 

The method of simulation developed in this work may not be the optimal one. One 
possible way to improve the simulation efficiency 1s to make the product-term algorithm 
more efficient. It 1s at the bottom of the hierarchy of the EPLD model and has the 
highest rate of execution. 

In order to save programming time and reduce programming errors, the modeler 
should thoroughly decompose the target circuit and establish the interface between all 


modules via entity declaration before actually programming the architecture body. 


C. RECOMMENDATIONS FOR FUTURE STUDY 

The study of this thesis is concerated on the EPLD gate level modeling. But, the 
VHDL modeling technique and the modules built in this study can be applied to other 
logic system designs. The future study can be directed toward establishing a EPLD 


component library to support the increasing EPLD implementation in designs. 
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APPENDIX A. VHDL SOURCE CODE FOR EP310 AND EP1800 
MODELS 


A. VHDL SOURCE CODE FOR EPLD_PACKAGE 


package EPROM_ PACK is. 
type irieis (Ul Omeeee 
type tri_vec is array (NATURAL range<>) of Tri; 


function resolver(signal inputs: tri_vec)return Tri; 


subtype tri_state is resolver Tri; 
type tri_vector is array (NATURAL range<>) of tri_state; 


function check_Pterm(P_string 
String, 
tri_vector) return BIT; 
function bit_toltri( innitr bit) returm tries rare: 
function tri_to bitCimbit.) Trivstate) erectus: 
function trivec_to_bitvec(inbits: tri_vector) return bit_vector; 
function bitvec_to_trivec(inbits: bit_vector) return tri_vectew 


end EPROM_PACK; 


package body EPROM_PACK is 


function resolver(signal inputs: tri _vec) return tri is 


variable resolved_value: tri:= 'U'; 
variable flag: integer:= 0; 
begin 


forei- in ineurs: range loop 
alse inputs(i)/=' U' then 
flag:= flagtl, 
resolved_value: = inputs(i); 
end if; 
end loop; 
assert flag <= 1 
report "“iopin bus collision. ' 
severity FAILURE; 
return resolved value; 
end resolver; 


function check_Pterm(P_string 
String; = 
tri_vector) return BIT is 
variable P_loc: natural: =0; 
variable ou: bit:='1'; 
variable i: positive: = 
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begin 
while i <= P_string' length loop 

if(P_string(i)='0' and P_string(it+1)='0') then 
ou: = : 
exit; 

end if; 

if(P_string(i)='1' and P_string(itl)='1')then 
po loew—reloc+ i: 

end if; 

-- select the true input. 

if(P_string(i)='1' and P_string(it1)='0') and 

(x((it1)/2)='U! or x((it1)/2)='0') then 
ui =O; 


exit; 
end <1£: 
-- select the complement input. 
if(P_string(i)='0 and Pesce aig mal) and 
xe) 7 2)—-U wor x((i41)/2)= 1°) then ‘ 
ou: = 0'; 
exit; 
end if; 
i: =it2; 
end loop; 
mies loc = ((P_ string length)/2) then 
ou:='1'; 
end if; 
return ou; 
end check_Pterm; 


mimetron bit_to_tri(inbit: bit) return Tri_state is 
begin 
if inbit='1' then 
met ianiie |. 
else 
return '0'; 
end if; 
PHawpi1t to_tri; 


Sujetion tri to_bit(inbit: Tri_state) return bit is 
begin 
if inbit='1' then 
Eeturme 1 ; 
else 
Eecurn, @) 4 
end if; 
enaestrie to bit: 


function trivec_to_bitvec(inbits: tri_vector) return bit_vector is 
variable local: bit_vector(inbits' range); 
begin 
fOr er in inbits ‘range loop 
if inbits(i)='1' then 
focal(i)x=" 1 < 


dD 


else 
local(i):='0'; 
end if; 
end loop; 
return local; 
end trivec_to_bitvec; 


function bitvec_to_trivec(inbits: bit_vector) return tri_vector is 
variable local: tri_vector(inbits' range); 
begin 
fou isin inbits range loop 
if inbits(i)='1' then 
local(i):='1'; 
else 
localGiae 20 
end if; 
end loop; 
return local; 
end bitvec_to_trivec; 


end EPROM_PACK; 
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B. VHDL SOURCE CODE FOR EP310 MODEL 


package EP310_PACK is 
subtype I0_string is string(1l to 7); 
-- IO_string 1 to 7 are switches inside the io architecture; 


type I0_array_type is array(1l to 8) of IO_string; 
subtype P_string is string( 1 to 36); 
type P_array_type is array(NATURAL range<>) of P_string; 


type EP310_TYPE is record 
P_array: P_array_type(l1 to 74); 
TIOQ_array: JIO_array_type; 

end record; 


-- the timing data are for EP310. 
eemsctant tin: [IME:=10 ns; 
constant tio: TIME: =2 ns; 
Constant tlad: TIME: =27 ns; 
constant tod: TIME: =12 ns; 
constant tzx: TIME: =0 ns; -- tzx(here) 
constant txz: TIME: =0 ns;-- txz(here) 
constant tsu: TIME: =10 ns; 
constant th: TIME: =10 ns; 
constant tch: TIME: =16 ns; 
Genstant tics: TIME: =4 ns; 
constant tfd: TIME: =5 ns; 
Senstant tclr: TIME: =33 ns; 


tzx(table)-tod; 
txz(table)-tod; 


function READ _JEDEC(F_name 
mieeans) return EP310_TYPE; 


end EP310_PACK; 


use STD. TEXTIO. all; 
package body EP310_PACK is 
function READ_JEDEC(F_name 
eerame) return EP310_TYPE is 
file F: text is in F_name; 
variable temp: line; 
variable temp_char: character; 
variable JO_temp: string(1 to 2730); 
waniable BP310_MAP: EP3I0_TYPE; 
variable flag: boolean :=true; 
variable GOOD,L_flag: boolean: =false; 
variable j,k: integer: =1; 
begin 
-- cut out the unwanted portion. 
while flag loop 
readline(F,temp); 
read(temp,temp_char); 
if(temp_char= *') then 


Mi 


L_flag: =true; 
end if; 
if(temp_char='L' and L_flag) then 
flag: =false; i 
end if; 
assert not endfile(F) 
report Ihe input tile 45 mot correc © 
end loop; 
-- extract the bit map information. 

while not endfile(F) loop 

readline(F,temp); 

j: =temp. all' length; 

I10_temp(k to k+j-1):=temp. all; 

k:= kt+j; 
end loop; 
for i in EP310_MAP. p_array' range loop 

EP310_MAP. p_array(i): =I0_temp(1+36*(i-1) to i*36); 
end loop; 
for i in EP310_MAP. 10_array'range loop 

EP310_MAP. IO_array(i): =IO_temp(2665+7*(i-1) to 2664+7%*i); 
end loop; 
return EP310_MAP; 


end READ_JEDEC; 
end EP310_PACK; 
Jeredevevedere dere dese deveveveveve se deve Fe vedo ve Fede tet Tete Fe Fete Fee Ne Te Me TNE eI EH Hee TNT TN 
library EP31LOLIB, SHU: 
use EP310LIB. EP310_PACK. all ,SHU. EPROM_PACK. ale. 
entatyee rs Loris 
generic (JEDEG: in string); 
port (pin_1,pin_2,pin_3,pin_4,pin_5,pin_6,pin_/,pin_§, panes oes 
in tri_state; pin_12,pin_13,pin_14,pin 15, pin_l69piieee 
pin_18,pin_1)9: ineut triestatrew. 
end EP310; 


library EPSIOETB sHu: 
use EP310LIB. EP310_pack. all,SHU. EPROM_PACK. all; 
architecture STRUCTURAL of EP310 is 


component MACROCELL 
generic(macro_P_array: P_array_type(1l to 9)); 
port(a 
tri _vector® » toe1s). 
OT Out, Een? OUE-bat): 
end component; 


component P_term 

generic( P: P_string); 

port(x: in tri_vector(l] to 18)5 ploue- sone oie)- 
end component; 


component JO_control 
generic(IO: Io_string); 
port(clk,or_in,preset,clear 
bate 
10_pift 
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moi state; 
SUEpiE. feedback, out tri state); 
end component; 


weenal Macro in : tri_vector(1 to 18); 

Signal oeloc,orloc: bit_vector(l to 8); 

signal local,output, feedback: tri_vector( 1 to 8); 
signal clear,preset: bit; 


constant BIT_MAP: EP310_TYPE := READ_JEDEC(JEDEC); 


--configuration specifications. 
for all: MACROCELL use entity EP310LIB. MACROCELL(behavioral); 
for all: P_term use entity EP310LIB. P_term( behavioral); 
for all: IO_CONTROL use entity EP310LIB. IO_CONTROL( behavioral_1); 
begin 
macro_in(1)<= pin_1 after tin; 
fiaecorin(2)<= pin_1l1 after tin; 
macro_in(3)<= pin_2 after tin; 
macro_in(4)<= feedback(1); 
macro_in(5)<= pin_3 after tin; 
macro_in(6)<= feedback(2); 
macro_in(7)<= pin_4 after tin; 
macro_in(8)<= feedback(3); 
macro_in(9)<= pin_5 after tin; 
macro_in(10)<= feedback(4); 
macro_in(1l)<= pin_6 after tin; 
macro_in(12)<= feedback(5); 
macro_in(13)<= pin_/7 after tin; 
macro_in(14)<= feedback(6); 
macro_in(15)<= pin_8 after tin; 
macro_in(16)<= feedback(7); 
macro_in(17)<= pin_9 after tin; 
macro_in(18)<= feedback(8); 


-- generate eight macrocells. 
fo fOr i in 1 to 8 generate 
macro: MACROCELL generic map(BIT_MAP. P_array(1+9*(i-1) to 9*i)) 
port map(macro_in,orloc(i),oeloc(i)); 
end generate; 


-- produce D_register preset input. 
P: P_term generic map(BIT_MAP. P_array(73)) 
port map(macro_in,preset); 


-- produce D_register reset input. 
R: P_term generic map(BIT_MAP. P_array(74)) 
port map(macro_in,clear); 


-- generate eight IO_control element. 
CON: for iin 1 to 8 generate 


CONTROL: JIO_control generic map(BIT_MAP. IO_array(i)) 
port map(tri_to_bit(pin_1'delayed(tics+tin)), 
orloc(i),preset,clear,local(i),output(i), 
feedback(i)); 


79 


end generate; 


local(1)<= output(1) after tiottin 
piney rarter tiozei, 


local(2)<= output(2) after tiottin 
pin_18 after tiottin; 


local(3)<= output(3) after tiottin 
pin_l? aftemsriortin., 


local(4)<= output(4) after tiottin 
pinzlo after tiotiein, 


local(5)<= output(5) after tiottin 
pin 15 “after ciottin, 


local(6)<= output(6) after tiottin 
pin_14 after tiottin; 


local(7)<= output(7) after tiottin 
pin_13:) afverstiottin, 


local(8)<= output(8) after tiottin 
pin._1l2 afterseietean 


when oeloc(1)='1' 
when oeloc(2)='1' 
when oeloc(3)='1' 
when oeloc(4)='1' 
when oeloc(5)='1' 
when oeloc(6)='1' 
when oeloc(7)='1' 


when oeloc(8)='1' 


pin_19<= output(1) after 


U' after tod when 
"2 


pin_18<= output(2) after 


U' after tod when 
"We 


pin_17<= output(3) after 


U' after tod when 
hee 


pin_16<= output(4) after 


U' after tod when 
ys 


pin_15<= output(5) after 


U' after tod when 
Ups 


Pingo > output(6) after 


U' after tod when 
Phe 
$ 


pin_13<= output(7) after 


U' after tod when 
ce 
$ 


pin_12<= output(8) after 


'U' after tod when 


tod when oeloc(1)='1' else 
oeloc(1)='0' else 
tod when oeloc(2)='1' else 
oeloc(2)='0' else 
tod when oeloc(3)='1' else 
oeloc(3)='0' else 
tod when oeloc(4)='1' else 
oeloc(4)='0' else 
tod when oeloc(5)='1' else 
oeloc(5)='0' else 
tod when oeloc(4)='1' else 
oeloc(6)='0' else 
tod when oeloc(7)='1' else 
celoc(7)= 0 else 
tod when oeloc(8)='1' else 


oeloc(8)='0' else 
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else 


else 


else 


else 


else 


else 


else 


else 


treat. 
8 ae : 


end STRUCTURAL; 
Jksodccndonkiciokcccccninkescscvcdescacsede sessed iedeseacdeabscsevede dese sesesesese sessed 
ibrary BP310LIB,SHU; 
use EP310LIB. EP310_pack. al1,SHU. EPROM_PACK. all; 
entity MACROCELL is 
generic (macro_P_array: P_array_type(l to 9)); 
port(a 
bemevector( 1 to 18); or_out,en: out bit); 
end MACROCELL; 


meoerary &EP310LIB,SHU; 
use EP310LIB. EP310_pack. all1,SHU. EPROM_PACK. all; 
architecture behavioral of MACROCELL is 
component P_term 
generic(P: P_string); 
port(x 
imeievector( | to 18); p_out: out bit); 
end component; 
Signal loc: bit_vector(1 to 8); 
signal en_loc: bit; 
for all: P_term use entity EP310LIB. p_term( behavioral); 
begin 
-- generate 8 P_terms. 
P: for iin 1 to 8 generate 
element: P_term generic map(macro_P_array(i)) 
port map(a,loc(i)); 
end generate; 


OE: P_term generic map(macro_P_array(9)) 
port map(a,en_loc); 
eeeoue-— 1 when loc(lj='1 or loc(2)= 1° or loc(3)='1' or 
foes) =o loc > )— 1 sor dloc(6)=a1— ‘or 
loc(7)=' 1" or loc(8)='1' else 
OF; 
en<x= en_loc after tzx; 
end behavioral; 
Fevedededsdode de eve Te Tove Ts Tete de te Fs He Tete KFC Ve Ie Fee Hee Te FICK CT PT ICR TRIKE RK 
iorary BPSLOLIB,SHU; 
use EP310LIB. EP310_pack. all ,SHU. EPROM_PACK. all; 
emiacy io control is 
generic(10: IO_string: ="'0000000"); 
port(clk,or_in,preset,clear 
baece= 0 }i0 pin: in tri_state:='U'; 
output, feedback: out tri_state); 
end io_control; 


Pibrary EP310LIB,SHU; 
use EP310LIB. EP310_pack. all,SHU. EPROM_PACK. all; 
architecture BEHAVIORAL_1 of io_control is 
component D_register 
generic(10: IO_string: ="'0000000"'); 
port(d,ck,preset,clear: in bit:='0';q: inout bit); 
end component; 
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signal Q_loc: BIT: ='0'; 
for all:d_register use entity EP310LIB. d_register(behavioral_2); 
begin 
D1: D_register generic map(I0O) 
port map (or_in,clk,preset,clear,Q loc); 


process(io_pin,or_in,Q_loc) 
begin 
-=- OUTPUT SELECT. 
if 1l0@i)= 6 femen 
OUtput<— bil_toerri(not one. 
elsat 10(2)= 0 enen 
Output<= bit oto triloman).; 
elsif 10(3)='0' then 
output<= bitstoltri(not Celoenm: 
elsif 1004) = 0 tien 
output<= bit_to_tri(Q_loc) ; 
else infle 
output<= ‘'U'; 
end if; 


«« FEEDBACK SELECT. 
if 10(5)= O-tnen 
feedback<=bit_to_tri(or_in) after tfd; 
elsat 1OC6)— 0 etnen 
feedback<=bit_to_tri(Q_loc) after tfd; 
elsif I10(7)='0' then 
feedback<=io_pin; 
else 
feedback<= 'U'; 
end if; 
end process ; 
end BEHAVIORAL_1; 
Hsedesedesede seve dete de dove deTe sek Fete ke Keto RVC KRABI ERIK RRR RK 
library EP310LiE yon: 
use EP310LIB. EP310_PACK. al1l,SHU. EPROM_PACK. all; 
entity D_register is 
generic( 10) 10 string: = 11110 
port(d,ck,preset,clear 
bit: =0 - q:ouusbie)- 
end D_register; 


library EP310LIB,SHU; 
use EP310LIB. EP310_PACK. al1,SHU. EPROM_PACK. all; 
architecture BEHAVIORAL_2 of D_register is 
begin 
EDGE_TRIGGERED_D: 
block ((ck='1' and not ck'stable) or clear='1') 
signal s: bit; 
begin 


-- check setup time of D_register. 
assert ck'stable or (ck='0') or d'stable(tsu) or (clear='1') or 
(I0(3)='1' and I0(4)='1' and 10(6)='1') 
-- not( not ck'stable and (ck='1') and not d'stable(tsu) 
-- and (clear='0')) and (10(3)='0' or 10(4)='0' or 10(6)='0') 


report "Setup Time Failure." 
severity FAILURE; 


== check hold time of d register. 


assert 


report "Hold Time Failure. 


ck’ delayed(th)'stable or (ck delayed(th)='0') or 

d' stable(th) or (clear=" ley Or 

CloCa)= 1° and Foc4)=- 1) ~and 10(6)= 1° ) 

not (not ck'delayed(th)' stable and (ck' delared(th)=' O') and 
not d' stable(th) and (clear=' O') and (10(3)='0' or 
10(4)='0' or 10(6)='0')) 


ft 


severity FAILURE; 


-- check setup time of D _register. (preset) | 


assert 


report "Setup Time Failure. 


ck'stable or (ck='0') or preset “stable(tsu) or (clear='1') or 
(10(3)='1' and 1CC4 =e and 10(6)=' es) 

not( not ck' stable and (ck='1') and not 8 anal ‘stable(tsu) 
and (elecam—sO manda 10(3)= 0 or 10(4)= 0 or 10(6)=0')) 


1? 


severity FAILURE; 


-- check hold time of d _register. (preset) 


assert 


report "Hold Time Failure. 


ck' delayed(th) | stable or (ck' delayed(th)=' O wer 

preset 'stable(th) or (clear=' 1') or 

GG =e wand 10(4)— 1° and 10(6)= 1’) 

not (not ck'delayed(th)'stable and (ck'delayed(th)='0') and 
not preset stable(th) and (clear='0') and (10(3)='0' or 
MeOCa)= 90) “or 10(6)='0')) 


tf 


severity FAILURE; 


-- check minimum pulse width of d_register. 


assert 


report 


ck'stable or (ck='1') or ck'delayed'stable(tch) or (10(3)='1' 
and 10(4)='1' and I0(6)='1') 

not (not ck'stable and ck='1' and ck'delayed'stable(tch) and 
Ute) —s0eror 10(4)— 0 or 10(6)= 0 )) 

"Minimum Pulse Width Failure." 


severity FAILURE; 


s<= guarded '1' when (preset='1' and clear='0') else 


d when (clear='0' and preset='0' and ck='1' and not ck'stable) 
else 
wOiusatter telr when clear='1 elise 
S; 
G<= Ss; 


end block EDGE_TRIGGERED_D; 
end BEHAVIORAL _2; 
GR piri Cite tietae setde bard hdr [tr ik fod Sear OL SL Oe Le RAR RR RR RR ER ei LS 
imterary EP3IOLIB,SHU; 
ieee rO1LOLIB. EP310_pack. all,SHU. EPROM_PACK. all; 
entity P_term is 
generic(P: P_string); 


pore( xX: 
end P_term; 


iimeaiavectoOr ol to 16);, pzout: out bit); 
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library EP310LIB, SHU; 
use EP310LIB. EP310_pack. all,SHU. EPROM_PACK. all; 


architecture behavioral of P_term is 
begin : 
process(x) 
variable c: BIT; 
begin 
c:=check_Pterm(P,x); 
p_out<= c after tlad; 
end process; 
end behavioral; 
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C. VHDL MODEL FOR EP1800. 


library SHU; 
use STD. TEXTIO. all,SHU. EPROM_PACK. all; 
package EP1800_pack is 


subtype I10_string is string({1 to 5); 
-- IO0_string 1 to 7 are switches inside the io architecture; 


type JO_array_type is array(NATURAL range<>) of IO_string; 


subtype P_string is string( 1 to 88); 
type P_array_type is array(NATURAL range <>) of P_string; 
subtype input_line is tri_vector(1 to 44); 


mype EP1800_TYPE is record 
P_array: P_array_type(1l to 480); 
IO_array: IO_array_type(1 to 48); 
end record; 


-- all the time constants are for ep1800-2; 


constant tin: TIME: =10 ns; 
constant tio: TIME: =15 ns;-- tio(here):= tin(table)+tio(table); 
constant tlad: TIME: =40 ns; 
constant tlade: TIME: =35 ns; 
constant tod: TIME: =15 ns; 
@onstant tzx: TIME: =15 ns; 
constant txz: TIME: =15 ns; 
constant tsu: TIME: =12 ns; 
constant th: TIME: =30 ns; 
Constant tch: TIME: =24 ns; 
constant tic: TIME: =40 ns; 
constant tice: TIME: =35 ns; 
constant tics: TIME: =4 ns; 
constant tfd: TIME: =10 ns; 
eonstant tclr: TIME: =40 ns; 
constant tclre: TIME:= 35 ns; 

-- here we demonstrate overload function. (which with same function name 

Beeput differt input type). 
function REVERSE(A 

P_array_type(1 to 120)) return p_array_type; 
function REVERSE(A 

IO_array_type) return [O_array_type; 
function FINDCA 

IO_string; position: in natural) 

return character; 

function READ _JEDEC(F_name 

string) return EP1800_TYPE; 


end EP1800_PACK; 


package body EP1800_PACK is 
function REVERSE(A 
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P_array_type(1 to 120)) return P_array_type is 
variable rev_array: p_array_type(1 to 120); 
begin 
for i ine tol loge 
rev_array(121-10*(i) to 120-10*(i-1)) 
> =A(1+10*(i-1) to 10*(i)); 
end loop; 
Fevuri Leyearray, 
end reverse; 


function REVERSE(A 
IO_array_type) return [O_array_type is 
variable rev_array: I0_array_type(1 to A' length); 
variable c: positive:=1; 
begin 
for i in A'reverse_range loop 
rev_array(c):= A(i); 
Co =xetrh; 
end loop; 
Fecuin Teysariray, 
end reverse; 


function FIND(A 
IO_string; position: in natural) 
return character is 
begin 
return A(position),; 
end FIND; 


function READ _JEDEC(F_name 
string) return EPISOORT YER as 
file F: text is in F_name; 
variable temp: line; 
variable temp_char: character; 
variable IO_temp: string(1 to 42500); 
variable EP1800_MAP: EP1800_TYPE; 
variable flag: boolean :=true; 
variable GOOD,L_flag: boolean: =false; 
variable j,k: integer: =1; 
begin 
-- cut out the unwanted portion. 
while flag loop 
readline(F,temp); 
read(temp,temp_char); 
if(temp_char='*') then 
L_flag: =true; 
end if; 
if(temp_char='L' and L_flag) then 
flag: =false; 
end if; 
assert not endfile(F) 
report ‘The input file 4s nouscorreeue 
end loop; 
== extract the bit map intornazzon: 
while not endfile(F) loop 
readline(F,temp); 
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j:=temp. all'length; 

IO_temp(k to k+j-1):=temp. all; 

k:= k+j; 
end loop; 
for i in EP1800_MAP. p_array'range loop 

EP1800_MAP. p_array(i): =IO_temp(1+88*(i-1) to i*88); 
end loop; 
for i in EP1800_MAP. io_array'range loop 

EP1800_MAP. IO_array(i):=IO_temp(42241+5*(i-1) to 42240+ i*5); 
end loop; 
return EP1800_MAP; 


end READ_JEDEC; 
end EP1800_pack; 
BeBe IC IC TC ZC ee BC Se ee Te UC CN TE TA TET UCUCUC TCT U TUT IET RATT UE RT RATRRESTERTRRSRTRRERITRRERR TC ST 
library EP1800LIB, SHU; 
use EP1800LIB. EP1800_PACK. all, SHU. EPROM_PACK. all; 
entity EP1800 is 
peneric ( JEDEC : in string); 
meee pine 14, pin _15,pin_16,pin_17, 
pine eean 20epan 21,pin.22, 
pine4S,pin 249 ,pin 50,pin 51, 
Dite> s-o liao. pile) 5). pin. 0 
@eiestate:='U': 
pine plies, pines, pin >,pin_6,pin_7 , 
Peto npiies pin 1!0,pin_11,pin_12,pin_13, 
Piteeoepiiiece. Dil 25. pin 26,pin_2/,pin_28, 
Pimecocepin s0,pin 31,pin_32,pin_33,pin_34, 
pin soepin 37 ,pin_S8,pin_ 39,pin_40,pin_41, 
pin_42,pin_43,pin_44,pin_45,pin_46,pin_4/, 
Pim plies P1259, pin 60,pin 6lspin_ 62, 
panmoes, pill O4,p1n 65.pin _66,pin 67 pin. 68 
mines tri istate:= U ): 
end EP1800; 


iyprary EPL8OOLIB, SHU; 
use EP1800LIB. EP1800_pack. all, SHU. EPROM_PACK. all; 
arehniatecture STRUCTURAL of EP1800 is 


component QUADRANT 
generic(Q P_array: P_array_type(1l to 120); 
Q I0_array: I0O_array_type(1 to 12)); 
porte ( clobal bus: in ema. vector( 13 to 44); 
quad ic liceem Dit; 
MOM 7, 10.5 me 14, 10%5,10_6,1027, 
foo; INOUtL tri state; 
dead: “Outotriavector( 1 to 4); 
end component; 


Signal global_bus: tri_vector(13 to 44) 

: ='"' UUUUUUUUU UU UU UU UU U UU UU"; 
Signal quad_A,quad_B,quad_C,quad_D: tri_vector(1 to 4); 
constant BIT_MAP: EP1800_TYPE: = READ _JEDEC( JEDEC); 


--configuation specification. 
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for all: QUADRANT use entity EP1800LIB. QUADRANT( STRUCTURAL); 


begin 
-- Due to the proprietary reason, the global bus assignment statements 
-- were removed. 


pin_10<= 
pin_11<= 
pin_12<= 
pin_13<= 
pin_26<= 
pin_25<= 
pin_24<= 
pin_23<= 
pin_44<= 
pin_45<= 
pin_46<= 
pin_4/7<= 
pin_60<= 
pin_59<= 
pin_58<= 
pin_5/7<= 


quad_A(1) 
quad_A(2) 
quad_A(3) 
quad_A(4) 
quad_B(1) 
quad_B(2) 
quad_B(3) 
quad_B(4) 
quad_C(1) 
quad_C(2) 
quad_C(3) 
quad_C(4) 
quad_D(1) 
quad_D(2) 
quad_D(3) 
quad_D(4) 


after 
after 
after 
after 
after 
after 
after 
after 
after 
after 
after 
after 
after 
after 
after 
after 


tod; -- 
Goad-- 
tod; -- 
tod; -- 
tod; -- 
tod; -- 
tod; -- 
tod; -- 
tod; -- 
tod: -- 
tod; -- 
tod; -- 
tod; -- 
tod; -- 
tod; -- 
tod; -- 


Gon guelleye 
Gpan. 11s); 
Cp aimee), 
Gpin 13). 
(pine 6 yi: 
(pin. Zo. 
(pin_24); 
(pane 3): 
(joniseh 424) g 
(pin_45); 
(pin_46); 
(pin_47); 
(pin_60); 
(pang 
(pin_56); 
( pilin 7 ); 


- 


QA: QUADRANT 
generic map(BIT_MAP. P_array(1 to 120), 
BIT MAP. {OlLarray( Isto 12)) 
port map{global_bus,tri_to bit( pins! jypiane2. paneer 
pin_4,pin_5,pin_6, pins? {pineo pai. 
quad_A); 


QB: QUADRANT 
generic map(reverse(BIT_MAP. P_array(121 to 240)), 
reverse(BIT_MAP. IO_array(13 to 24))) 
port map( global _bus,tmmto_bit(pin 19)( pine24) paneer 
. pin_32@pin_31,pin_30 ;pin 29. pine6 pine 7 
quad_B); 


GC: QUADRANT 
generic map(BIT_MAP. P_array(241 to 360), 
BITMAP. 10. arr ay@2e to 36) 
port map( global _bus ,tri_to_bit(pin251)))pimmeo. pine. 
pin_38,pin_39,pin_40,pin_41,pin_42,pin_43, 
quad_C); 


Ob: QUADRANT 
generic map(reverse(BIT_MAP. P_array(361 to 480)), 
reverse(BIT_MAP. IO_array(37 to 48))) 
port map(global_bus,tri_to_bit( pine53)pinesoce pane co? , 
pin_66,pin_ 65 ,pin_64,p3nwoo, pimmee. ao mod, 
quad_D); 


end STRUCTURAL; 
dedededs deveveds fede vers ve ve Fede Te Ne Fe Te Fev Fe FeA Me Ne Fe Te Fe Mee Fe FC Ne Fe Fe Fe TEN Ie Te He Fe Ie He 
library EP1800LIB, SHU; 
use EP1800LIB. EP1800_PACK. all, SHU. EPROM_PACK. all; 
entity QUADRANT is 
generic(Q P_array: P_array_type(1l to 120); 
Q [0_array: T0larray typeC! to 125, 
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pore (globalebus: adn »tri_vector(13 to 44); 
quad_clk: in bit; 
10 | leomewtlons oman toms, 10 6,10 7, 
io_8: inout tri_state; 
GudgGe out tra. vector 1 ta 4). 
end QUADRANT; 


iiprary EP1800LIB, SHU; 
use EP1I800LIB. EP1800_PACK. all, SHU. EPROM_PACK. all; 
architecture STRUCTURAL of QUADRANT is 


component LOCAL MACROCELL 
generic(P_array: P_array_type(1 to 10); I0: IO_string; 
to lad: TIME: =t lad’ tlclr: TIME: =tclr; 
tec: ih =t2c ): 
port( inputs 
input_line; quad_clk: in bit; 
ee,output: out bit); 
end component; 


component GLOBAL_MACROCELL 
generic(P_array: P_array_type(1 to 10); I0: IO_string; 
t_lad: time: =tlade; t_clr: time: =tclr; 
t_ic: time: =tic); 
port(inputs 
input_line; quad_clk: in bit; 
oe,output: out bit); 
end component; 


signal oe,M_output: bit_vector(1 to 12); 
saemal local bus: tri_vector( 1 to 12); 
signal local: tri_vector( 1 to 8); 
signal inputs: input_line; 
for all: LOCAL_MACROCELL 
use entity EP1800LIB. LOCAL_MACROCELL( structural); 


for all: GLOBAL _MACROCELL 
use entity EP1800LIB. GLOBAL_MACROCELL(structural); 


begin 
inputs<= local_bus & global_bus; 


M1_E: LOCAL_MACROCELL generic map(Q_P_array(1 to 10),Q_I10_array(1), 
tlade,tclre,tice) 
port map (inputs,quad_clk, 
ee( l)ebNeoueput( 1)); 
Me _E: LOCAL_MACROCELL generic map(Q_P_array(1l to 20),Q_ I0_array(2), 
tlade,tclre,tice) 
port map (inputs,quad_clk, 
S62) Meoueput(2)); 


BS E: LOCAL_MACROCELL generic map(Q_P_array(21 to 30),Q_I0_array(3), 
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M4 _E: 


M5_GE: 


M6_GE: 


M7 2GE: 


MS_GE: 


M9_GL: 


1410_GL: 


M11_GL: 


MiZ26L: 


tlade,tclre,tice) 
port map (inputs,quad_clk, 
oe(3),M_output(3)); 


LOCAL_MACROCELL generic map(Q_P_array(31 to 40),Q_ 10_array(4), 
tlade,tclre,tice) 
port map (inputs,quad_clk, 
oe(4),M_output(4)); 


LOCAL_MACROCELL generic map(Q_P_array(41 to 50),Q_I0_array(5)) 
port map (inputs,quad_clk, 
oe(5),M_output(5)); 


LOCAL_MACROCELL generic map(Q_P_array(51 to 60),Q_I0_array(6) ) 
port map (inputs,quad_clk, 
oe(6),M_output(6)); 


LOCAL_MACROCELL generic map(Q_P_array(61 to 70),Q_I10_array(7)) 
port map (inputs,quad_clk, 
oe(7),M_output(7)); 


LOCAL_MACROCELL generic map(Q_P_array(71 to 80),Q _ I0_array(8)) 
port map (inputs,quad_clk, 
oe($)  M-outpucts)). 


GLOBAL_MACROCELL generic map(Q_P_array(81 to 90),Q_IO_array(9)) 
port map (inputs,quad_clk, 
oe(9) laurtpin 


GLOBAL_MACROCELL 
generic map(Q_P_array(91 to 100),Q_ 10_array(10)) 
port map (inputs ,quad_clk, 
oe( 10) ,M_output(10)); 


GLOBAL _MACROCELL 
generic map(Q_P_array(101 to 110),Q_I10_array(11)) 
port map (inputs,quad_clk, 
oe(11),M_output(11)); 


GLOBAL_MACROCELL 
generic map(Q_P_array(111 to 120),Q_ 10_array(12)) 
port map (inputs,quad_clk, 
oe(12),M_output(12)); 


io_1l<= bit_ to CtriCieoveaiccio after tod when oe(1)='1' else 


0' 


"U' after tod when cel lj)— O else 


oye 


io_2<= bit_to_tri(M_output(2)) after tod when oe(2)='1' else 


au after tod when oe(2)='0' else 
U; 


io _3<= bit_to_tri(Mgoutpures) after tod when oe(3)='1' else 


U" after tod when oe(3)='0' else 
U5 
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io_4<= bit_ to BeicNeoweput( 4) ) after tod when oe(4)='1' else 


'U! after tod when oe(4)='0' else 
Ue 

FO] o<=ebit _to BeErevmoutpuL( 3) ) after tod when oe(5)='1' else 
'U! after tod when o€(5)='0' else 
Wes 

io_6<= bit_to_tri(M_output(6)) after tod when oe(6)='1' else 
'U' after tod when oe(6)='0' else 
Os 


on7<= bit_to_tri(M_output(7)) after tod when oe(7)='1' else 
U! after tod when oe(7)='0' else 
U'; 

io_8<= bit_to_tri(M_output(8)) after tod when oe(8)='1' else 


ah after tod when oe(8)='0' else 
U ; 


local(1)<= bit_to_tri(M_output(1)) after tio when oe(1)='1' else 
io_l after tio; 


local(2)<= bit_to_tri(M_output(2)) after tio when oe(2)='1' else 
io_2 after tio; 


local(3)<= bit_to_tri(M_output(3)) after tio when oe(3)='1' else 
163 after tio; 


local(4)<= bit_to_tri(M_output(4)) after tio when oe(4)='1' else 
io_4 after tio; 


local(5)<= bit_to_tri(M_output(5)) after tio when oe(5)='1' else 
no™5mafter tio; 


local(6)<= bit_to_tri(M_output(6)) after tio when oe(6)='1' else 
io_6 after tio; 


local(7)<= bit_to_tri(M_output(7)) after tio when oe(7)='1' else 
lems atter £10; 


local(8)<= bit_to_tri(M_output(8)) after tio when oe(8)='1 else 
io_8 after tio; 


local_bus(1)<= local(1) when find(Q_IO_array(1),4)='0' else 
Ditmecontra(M output(1)) after tid; 


local_bus(2)<= local(2) when find(Q_I10_array(2),4)='0' else 
bitetcoutmi Mvoutpuc(2)) after tid; 


local_bus(3)<= local(3) when find(Q_IO0_array(3),4)='0' else 
Ditecomert( hooutput(3)) after tfd; 


local_bus(4)<= local(4) when find(Q_IO_array(4),4)='0' else 
bitmeoutri( Meoutcput( 4) yr after tfd; 


9] 


local_bus(5)<= local(5) when find(Q_I0_array(5),4)='0' else 
bit_to_tri( M_outputts)) atter secre: 


local_bus(6)<= local(6) when find(Q_IO_array(6),4)='0' else 
bit_to_tri( M_output(o)) satter tra. 


local_bus(7)<= local(7) when find(Q_IO_array(7),4)='0' else 
bit_to_tri(Meoutput(7)) aftemiend: 


local_bus(8)<= local(8) when find(Q_IO_array(8),4)='0' else 
bit_to_tri(M_outputts) ) attemet.c: 


local_bus(9)<= bit_to_tri(M_output(9)) after tfd; 

local_bus(10)<= bit_to_tri(M_output(10)) after tfd; 
local_bus(11)<= bit_to_tri(M_output(11)) after tfd; 
local_bus(12)<= bit_to_tri(M_output(12)) after tfd; 


quad(1)<= bit_ EOutr nt ma ae oe when oe(9)='1' else 


'U' when oe(9)='0 else 
on 

quad(2)<= bit_ to_tri(Ms output(10)) when oe(10)='1' else 
'U' when oe(10)='0' else 
suis 

quad(3)<= bit_ to -terr( iS output(11)) when oe(11)='1' else 
'U' when oe(11)='0' else 
mies 


quad(4)<= bit_ tO_triche ho when oe(12)=. 1, .elce 
as when oe(12)='0' else 


end SNe eee 
sevevevevevedede devedevededede de dededede deve dete dade dete ke de dede tede dete eve Fee RR ERR 
Meaey EP1800LIB, SHU: 
use EP1800LIB. EP1800_pack. all, SHU. EPROM_PACK. all; 
entity LOCAL_MACROCELL is 
generic(P_array: P_array_type(1 to 10); I0: IO0_string; 
t_lad: time: =tlad; t_clr: time: =tclr; 
tac; time: =tie), 
port( inputs 
input_line; quad_clk 
Dre: 
O€, OULPUE Out bie): 
end LOCAL_MACROCELL; 


library EP1800LIB, SHU; 
use EP1800LIB. EP1800_pack. all, SHU. EPROM_PACK. all; 
architecture STRUCTURAL of LOCAL_MACROCELL is 


component P_term 
generic(P: P_string; t_lad: time: =tlad); 
pore: 
input_line;: pvour voucs bie). 
end component; 


component 


IOQ_CONTROL 


generic(IO:IO_string; t_clr: time: =tclr); 


levied 


Horelomwnen.clk, clear 


output: out bit); 


end component; 


Signal local: bit_vector(1 to 10); 


signal or_ 


Outmcl kK: bit; 


for all: P_term use entity EP1800LIB. P_term( behavioral); 


mor all: 

begin 

eas P_term 
es P_term 
eo): P_term 
Pa: P_term 
Be: P_term 
Pe: P_term 
Py: P_term 
Ps: P_term 


GbR P: P term 


Oierer: P term 


IO_CONTROL use entity EP1800LIB. IO_CONTROL( behavioral); 


generic map(P_array(1),t_lad) 
port map(Cinputs,local(1)); 
generic map(P_array(2),t_lad) 
Pore Map Cinputs. locali(2 ) ):; 
generic map(P_array(3),t_lad) 
port map(inputs,local(3)); 
generic map(P_array(4) ,t_lad) 
port map( inputs, local(4)); 
generic map(P_array(5),t_lad) 
port map(inputs,local(5)); 
generic map(P_array(6),t_lad) 
port map( inputs, local(6)); 
generic map(P_array(/7),t_lad) 
port map(inputs,local(7)); 


generic map(P_array(8) ,t_lad) 
port map( inputs, local(8)); 
generic map(P_array(9),t_lad) 
port map( inputs, local(9)); 
generic map(P_array(10),t_ic) 
port map(inputs,local(10)); 


or_out<='1' when (local(1) or local(2) or local(3) 
Omelocal(4) or lLocal(5)) or local(6) 


or local(7) or local(s j= velse 


> 


OECK_S: process(quad_clk,local(10)) 


HOT: 


begin 


if 16(2)= 0 then 
clk<= quad_clk after tics; 
oe<x= local(10) after tzx; 


else 


clk<= local( 10); 
oe<='1' after tzx; 
end if; 
end process OECK_S; 


IO_CONTROL generic map(IO,t_clr) 


port map(or_out,clk,local(9),output); 


end STRUCTURAL; 


sevevevc ery oe 7 = we Sevess river ts ve wc ris seve vs ¥e dele se deveves vesvess ks Sevevevevess Seveveds peescses 
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library EP1800LIB, SHU; 
use EP1800LIB. EP1800_pack. all, SHU. EPROM_PACK. all; 
entity GLOBAL_MACROCELL is 
generic(P_array: P_array_type(1 to 10); I0: I10_string; 
t_lad: time: =tlad; t_clr: time: =tclr; 
t_ic: time: =tiae); 
port( inputs 
input_line; quad_clk 
baie: 
oe,output: out bit); 
end GLOBAL_MACROCELL; 


library EP1800LIB, SHU; 
use EP1800LIB. EP1800_pack. all, SHU. EPROM_PACK. all; 
architecture STRUCTURAL of GLOBAL _MACROCELL is 


component P_term 
generic(P: P_string; t_lad: time: =tlad); 
port(x: in inputl line; wpiout; voucwniec). 
end component; 


component IO CONTROL 
generic( IO: [O_string; t_clr:time:=tclr); 
port(or_in,clk,clear: in bit; 
OUtpUL! Cle, bit) 
end component; 


signal local: bit_vector(1 to 10); 
signal or_out,clk,oeck: bit; 


for all: P_term use entity EPI1800LIB. P_term( behavioral); 
for all: IO_CONTROL use entity EP1800LIB. IO_CONTROL( behavioral); 


begin 
Pa: P_term generic map(P_array(1)) 
port map(inputs,local(1)); 
Pee P_term generic map(P_array(2)) 
port map(inputs,local(2)); 
Pos P_term generic map(P_array(3) ) 
port map( inputs. localCs yy: 
P4: P_term generic map(P_array(4) ) 
port map(Cinputs,local(4)); 
Boy P_term generic map(P_array(5)) 
port map(inputs,local(5)); 
PG: P_term generic map(P_array(6) ) 
port map(inputs,local(6)); 
Pa P_term generic map(P_array(7) ) 
port map(inputs,local(7)); 
P8: P_term generic map(P_array(8)) 


port map(inputs,local(8)); 
CLR_P: P_term generic map(P_array(9)) 

port map(inputs,local(9)); 
OECK_P: P_term generic map(P_array(10),tic) 

port map(inputs,local(10)); 


or_out<='1' when (local(1) or local(2) or local(3) 
or local(4) or local(5) ommliecal(G 
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or local(7) Srerocde so). = else 
05 


OECK_S: process(quad_clk, local(10)) 
begin 
if I10(2)='0' then 
clk<= quad_clk after tics; 
oeck<= local(10); 
else 
clk<= local(10); 
oeck<='1'; 
ena if; 
end process OECK_S; 


OE_S: process(oeck) 
begin 
if I0(4)='0' then 
oe<= oeck; 
else 
co ‘0: 
end if; 
end process OE_S; 


Oo 1: IO_CONTROL generic map( IO) 
postamapcersour,clk,local(9) output); 


end STRUCTURAL; 
BeBe ae FE 26 0 eae UC IE IC IE BITTE IC IE CIC TE BOE TIE TE TE TOIT TE FOIE TE FETE TE IT TE IE IONE TE TE FE IO TE TE TOT IE IETS ETE TE ENE 
fprary EPI800LIB, SHU; 
use EP1800LIB. EP1800_pack. all, SHU. EPROM_PACK. all; 
entity IO_CONTROL is 
generic(IO:10_string; t_clr:time:=tclr); 
fone (or _in,clk,clear 
pat. Output: out bit); 
end IO_CONTROL; 


-- For architecture body source code please contect Prof. CHIN-HWA LEE, 
-- Naval Postgraduate School, Monterey, CA, 93943. 


Kaede dese Fede se dese Fede seve Fe Te Fee Ne ve ede TCI I Te II IK TET TK TTC KTR IK RICK KI 

mierary EPISOOLIB, SHU; 

use EP1800LIB. EP1800_pack. all, SHU. EPROM_PACK. all; 

entity D_register is 
generic(10: character: ='0'; t_clr:time:=tclr); 
port(d,clk,clear 

Bat:— 0°; gq: out bit); 

end D_register; 


meprary EPIS8OOLIB, SHU; 
use EP1I800LIB. EP1800_pack. all, SHU. EPROM_PACK. all; 
architecture BEHAVIORAL of D_register is 
begin 
EDGE_TRIGGERED_D: 
Block ((clk='1' and not clk’stable) or clear='1") 
Signal s: bit; 
begin 


oS, 


-- check next Setup time of D _register. 
assert clk’ stable or (clk= 0 ) or d'stable(tsu) or 
Celear— © eer 10= 
-- not( not clk'stable and (clk='1') and not d'stable(tsu) 
-- and (clear='0')) and I0='0' ) 
report "Setup Time Fialure.”" 
severity FAILURE; 


-- check hold time of d_register. 
assert clk'delayed(th) stable or (clk'delayed(th)='0') or 
easaD tet) or 
(clleare as) Or ie ak 
-- not (not clk'delayed(th)' stable and (clk' delared(th)=' 0') and 
-- not d'stable(th) and (elear= 0 ) and 10 —=sOmm 
report "Hold Time Failure." 
severity FAILURE; 


==) CHeGkK minimum pulse-width of d _register. i 
assert clk' stable On Ce lice alle) or clk' delayed’ stable(tch) or [0='1' 
-- not (clk’ stable and (clk='1' and clk'delayed'stable(tch) and 
-- I0= 0 ) 
report "Minium pulse width failure’ 
severity FAILURE; 


s<= guarded '0' after t_clr when clear='1' else 

d when (clear='0' and clk='1' and not clk'stable) else 
S; 

qs= 8; 


end block EDGE_TRIGGERED_D; 
end BEHAVIORAL; 
7 ir oie de sie okhinie) seliasoie eie ke ote e k ig ien e)or) egir a ae akakseo bok oieiedsiehweirokhaehsrs dehskasrigr iseagriyrise arco yriiriseicr i 
lgbrary BPPSOORIE shu: 
use EP1800LIB. EP1800_pack. all, SHU. EPROM_PACK. all; 
entity P_term is 
generic(P: P_string; t_lad: time: =tlad); 
POT ts 
input_line;” pleut; outeoie), 
end P_term; 


library EP1800LIB, SHU; 
use EP1800LIB. EP1800_pack. all, SHU. EPROM_PACK. all; 
architecture behavioral of P_term is 
begin 
process(x) 
variable c: BIT; 
begin 
c: =check_Pterm(P,x); 
p_out<= c after t_lad; 
end process; 


end behavioral; 
Tesedesededctevedeseseseseslcslestedescucskedkacde kek teseseseskcskeakvscde testes sede deve 
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APPENDIX B. VHDL CODE FOR TEST_BENCH 


A. VHDL SOURCE CODE FOR TOP ENTITY DECLARATION. 


-- NOTE: In the top-level design unit there can not have TIME generic 
“- parameter, other wise there will have a error message in model 

-- generate(MG) state and the MG process will stop without creating any 
== object file. 


entity TEST_BENCH is 
generic (ck_rate: integer:= 20000000; 
term_sim: integer:= 10; 
delay: integer:=1000); -- delay unit ns. 
end TEST_BENCH; 


ot 


B. TEST_BENCH ARCHITECTURE BODY FOR EP310 


library EF310biR SoHu: 
use EP310LIB. ep310_pack. all ,SHU. EPROM_PACK. all; 
architecture ep310 of test_bench is 
component ep310 generic(JEDEC: in string); 
port(pin_1,pin_2,pin_3,pin 4,pin_5 ,pine6, pp. ue 
pin 8 ,pin_9,pin Jl. in teiescacc, 
pin_1l2,pin_13,pin.14,pin 215, pinz16 ; paren 
pin_13,pin_l3- inoue triesctace=). 
end component; 


signal pin. 1],pin=2Z,pings-pine4 pine .pineo- 
pin_7,pinoc,pin 9,pino lie tci state —aUe 

signal pin_i2,pin_13,pincia-pine 1 joiner 
pin_17,pin_18,pin_19: resolver tri_state:= 'U'; 

signal input: trisvector( | test). 

Signal 10: trizvector() 1 to 3): 

signal count: integer :=0; 

signal clock: bit:='0'; 


for all : ep310 use entity EP310LIB. ep310(structural); 
begin 


EP1:EP310 generic map("cntr7. jed") 
port map(pin_1,pin_2,pin_3,pin_4,pin_5,pin_6, pane 
JSphamcoy song ek jony ols ils 
pin_12,pin_13,pin_14,pin_15,pin_16, pine 
Pails. pinesl I). 


CLOCK_GENERATOR: process(clock) 

begin 
clock<= not clock after 1 sec / ck_rate; 
pin _ i<—= bit _tooprit elec: 

end process CLOCK_GENERATOR; 


pin_3<= 1% --after 2 sec /ck_rate; ENABLE. 
pin_2<='0'; --after 1 sec/ck_rate; RESET. 


TERMINATE: process(count ) 
begin 
assert (count /= term_sim) 
report "simulation is done."; 
end process TERMINATE; 


1O_INPUT; block(clock = 1 } 
begin 

pin_19<= guarded '1'; 
end block IO_INPUT; 


count<= count+l after delay*ns; 


input<= pin_1l & pin_2 & pin 3 & pinls © pineS © pingons pane 
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Sapineose pin 7 & pam) |; 
fo <—- pingl2 & pin_i3 & pin_1l4 & pin_15 & pin_16 & pin_17 & pin_18 
Spin. 19: 
end ep310; 


Ne 


DEC-05-1956 sya w2e 


VHDL Report Generator 


Vhdl Simulation Report 


Kernel Library Name: <<SHU>>TEST_EP3 
Kernel Creation Date: DEC-05-1988 
Kernel Creation Time: 17:11:16 


Run Identifer: 1 
Run Date: DEC-05-1988 
Run Time: 17:11:16 


Report Control Language File: TEST_EP310. RCL 
Report Output File : TEST_EP3. RPT 


Max Time: 9223372036854775807 


Max Delta: 2147483646 


Report Control Language : 


simulation_report s is 

begin 
page_width is 72; 
select_signal : 
select_signal : 
select_signal : 
select_signal : 
sample_signals b 

end; 


1 c" 


c =>pin_19; 
clk"=>pin_ 1: 
pin_ 2 ier. 
pin_12 - pin_18"=> io(1 to 7); 
escent alb gaat oltre 


Report Format Information : 


Time is in NS relative 
Time period for report 
Signal values are repo 


to the start of simulation 
is from O NS to End of Simulation 


PAGE 1 


rted by event ( ' ' indicates no event ) 
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WEE=05-198S 17:18:20 VHDL Report Generator PAGE 2 


c clk Pa Nie2 PIN 3 pin_12 - pin_18(1 TO 7) 


1 ' 1 1 ' 1 t t "UUUUUU tt 
U a 19! oe u 


"9000000" 


js 
— 


"9000001" 


"9000010" 


"9000011" 


''99000100" 


"9900101" 


ToOoOooOn 10) | 


“OOOOt) 


Od 
in 
© 
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ak 
800 
521! 


"0001000" 


C. TEST_BENCH ARCHITECTURE BODY FOR EP1800 


library EP1800LIB, SHU; 

use EP1800LIB. EP1800_PACK. all, SHU. EPROM_PACK. all; 

architecture ep1800 of test_bench is 

component EP1800 
generic (JEDEC : in string); 
more (pin_14,pin_15,pin_1l6,pin_1/7, 

pin_19,pin_20,pin_21,pin_22, 
pin_ 48,pin_49 ,pin_50,pin_51l, 
a 53,pin_54,pin_55,pin_56 

tri_state: 5 
i aes OS CS A ner. 
Piieo, Dino, pide TO sOined mines pin 13. 
pitig2o pilie2+,pinoz5,pin_26,pin_ 27 ,pin Zs, 
Plime pin. s0,pin.ol,pin_32,pin_33,pin_34, 
pans sempre s/ pin 36,pin_39,pin_40,pin_41, 
pin_42 ,pin_43,pin_44,pin_45,pin_46,pin_47, 
Pane pine so, pin 59 ,pin_60,pin_61,pin_62, 
pineos pin 64,pin 65,pin 66,pin_6/7,pin_66 
winout tri state:= 0 ): 

end component; 


Signal DNUP , CLOCK, LOAD , RESET 
meriestate,— 0 ; 

signal Q: tri_vector(1 to 16):=''0000000000000000"; 

signal D: tri_vector( 1 to 16):="0000000000000000"; 

meenal ck: bit :='0'; 

signal c: positive: =1; 
wemconiiguration specification 

for all : ep1800 use entity EP1800LIB. ep1800(structural); 
begin 


-- use named association interface list. associated lists are ee a agne to 
-- chip map from ALTERA Design Processor Utilization Report. 


EP1:EP1800 generic map(‘'count. jed') 
port map(pin_2=>Q(9),pin_3=>Q( 10) ,pin_4=>Q(11), 

panes 20 2) pin o—-0( 15), pin_7=-Q¢( 14), 
Pineo—200'5) pin. 7—"0( 16), pin  10—-Q{ 1), 
pine 11=2Q(2),pin_12=>0Q(3) ,pin_13=>Q(7), 
pin_16=>DNUP, pin_17=>CLOCK, pin_19=>D(8), 
pin_20=>D( 9) ,pin_21=>D( 10) ,pin_22=>D( 11), 
pin_23=>D(1),pin_24=>D(2) ,pin_25=>D(3), 
pin_26=>D(7),pin_48=>D( 12) ,pin_49=>D( 13), 
pin_50=>D( 14) ,pin_51=>D(15) ,pin_53=>CLOCK, 
pin_54=>D(16),pin_55=>LOAD , pin_56=>RESET, 
pin_ 57=>Q(4) ,pin_58=>Q(5) ,pin_59=>Q(6), 
pin_60=>Q(8) ,pin_66=>D(4) ,pin_67=>D(5), 
pin_68=>D(6)); 


CLOCK_GENERATOR: process(ck) 


begin 
ck<= not ck after delay*«ns; 
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CLOCK<= bit_to_tri(ck); 
end process CLOCK_GENERATOR; 


DNUP <= '1'; -- up counter. 
RESET <= '1' when c = 1 else 
0 ° 


LOAD <= 4 when c = 2 else 
05 
c<= c+l after delay*ns; 
TERMINATE: process(ck) 
begin 
assert (NOW /= term_sim*delay*ns ) 


report ‘simulation is done."; 
end process TERMINATE; 
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DWECG-05-1988 17:19: 44 


VHDL Report Generator 


Vhdl Simulation Report 


Kernel Library Name: <<SHU>>TEST_COUNT 
Kernel Creation Date: NOV-24-1988 


Kernel Creation Time: 14:37: 26 


Run Identifer: 1 
Run Date: NOV-24-1988 
Ron Dame: “14: 37: 26 


Report Control Language File: TEST_EP1800. RCL 
Report Output File : TEST_COUNT. RPT 


Max Time: 9223372036854775807 


Max Delta: 2147483646 


Report Control Language : 


simulation_report COUNT_UP is 


begin 
page width is 


select_signal : 


V2 


select_signal : 
select_signal : 
select_signal : 


select_signal : 
sample_signals 


end; 


ib 


'RE'=>RESET; 
"c1k"=>CLOCK: 
10; => LOAD: 
"DNUP"=> DNUP; 
Q; 


y_event in ns; 


Report Format Information : 


Time is in NS relative to the start of simulation 
Time period for report is from 0 NS to End of Simulation 


Signal values are reported by event ( 


! 
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PAGE 1 


indicates no event ) 


DEC-05-1988 17:19:44 


VHDL Report Generator 
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DNUP 


Q(1 TO 16) 
" YUUUUUUUUUUU UU" 
"00000000UUUUUUUU" 


"O000000000000UUUU" 
"'9000000000000000" 


"1000000000000000" 


''0100000000000000"' 


''1100000000000000" 


''9010000000000000" 


''7010000000000000" 


"0110000000000000" 


''7110000000000000" 


''9001000000000000" 


PAGE 2 


Soy) | om 
19000 | ie 
+1 | 1 
19019 | '1001000000000000" 
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APPENDIX C. EXAMPLES OF SIGNAL SELECT FILE AND SIGNAL 
MAP FILE 


A. SIGNAL SELECT FILE 

~~ selected trace signals for test_ep1800 are 
> RESEO: 

; ChOEK; 

: LOAD; 

: DNUP; 

Pk 
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CLOCK ; 
COUNT ; 


B. SIGNAL MAP OF THE TEST_EP3 MODEL 
MEG=13-1988 14: 26: 12 


VHDL Simulator 
SIGNAL NAME MAP 
KERNEL = <<SHU>>TEST_EP3 


INPUT(1 TO 10) ; 
Hoc TO 8) ; 


EeeN: 1 ; 
EIN 11 
Pen 12 
EON 13 
PIN_14 
PIN_15 
PIN_16 
PIN 17 
PIN_18 
RIN. 19 
PaN 2 ; 
RON 3 ; 
PING ; 
Pen 5 ; 
RIN 6 ; 
EAN 7 ; 
Pen 8 ; 
Een 9 ; 


10. ENPUT : 


we we Wwe we we we Wwe Wwe Wwe 


GUARD ; 


Peel : 
veel : 
Weel : 


CLEAR ; 


FEEDBACK(1 TO 8) ; 
LOCAL(1 TO 8) ; 
MACRO_IN(1 TO 18) ; 
OELOC(1 TO 8) ; 
ORLOC(1 TO 8) ; 
OUTPUT(1 TO 8) ; 


FIN 1 ; 


3 


RON 11 
Ne 12 
EN 13 
PIN_14 
BUN 1S 
PIN 16 
BNL, 
PAN ls 
EIN. 19 
RUN 22 
FINsS 
PIN_4 
FaLNS 
PINS6 
RUN 7 
Nas 
EON. 
Pe Beda 


/EP1. CON(1) : 


we we we Wwe Wwe Wwe Wwe Wwe 


we we we we we we Wwe Wwe we 


CLK'TYPE_CONV_79_C : 
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PAGE 1 


/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 


CON(1) : PIN_1'DE 
CON(1)/CONTROL : 
CON(1)/CONTROL : 
CON(1)/CONTROL : 
CON(1)/CONTROL : 
CON(1)/CONTROL : 


DEG 13-198 6514. 26. 12 


/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 


CON(1)/CONTROL : 
CON(1)/CONTROL : 
CON(1)/CONTROL : 
CON(1)/CONTROL/D1 : 


CON(1)/CONTROL/D1 : 
CON(1)/CONTROL/D1 : 
CON(1)/CONTROL/D1 : 


CON(1)/CONTROL/D1 : 


CON(1)/CONTROL/D1. 
CON(1)/CONTROL/D1. 
CON(1)/CONTROL/D1. 
CON(1)/CONTROL/D1. 
CON(1)/CONTROL/D1. 
CON(1)/CONTROL/D1. 
CON(1)/CONTROL/D1. 
CON(1)/CONTROL/D1. 
CON(1)/CONTROL/D1. 
CON(1)/CONTROL/D1. 
CON(1)/CONTROL/D1. 
CON(1)/CONTROL/D1. 
CON(1)/CONTROL/D1. 
CON(1)/CONTROL/D1. 
CON(1)/CONTROL/D1. 
CON(1)/CONTROL/D1. 
CON(1)/CONTROL/D1. 
CON(1)/CONTROL/D1. 
CON( 1)/CONTROL/D1. 


CON(2) : CLK'TYPE 
CON(2) : PIN_1'DE 
CON(2)/CONTROL : 
CON(2)/CONTROL : 
CON(2)/CONTROL : 
CON(2)/CONTROL : 
CON(2)/CONTROL : 
CON(2)/CONTROL : 
CON(2)/CONTROL : 
CON(2)/CONTROL : 
CON(2)/CONTROL/D1 : 


CON(2)/CONTROL/D1 : 
CON(2)/CONTROL/D1 : 
CON(2)/CONTROL/D1 : 


CON(2)/CONTROL/D1 : 
CON(2)/CONTROL/D1. 
CON(2)/CONTROL/D1. 


CON( 2) /CONTROL/D1. 
CON(2)/CONTROL/D1. 


LAYED_79_A ; 
CLEAR ; 

CLK 
FEEDBACK ; 
POSPIN 
OR_IN ; 


VHDL Simulator 
SIGNAL NAME MAP 
KERNEL = <<SHU>>TEST_EP3 


GUTLEUiIys: 
PRESSED: 
QELOe 
Ce: 
CLEAR : 
D 
PRESET ; 


_CONV_79_C ; 
LAYED_79_A ; 
CLEAR ; 
CilbKoe: 
FEEDBACK ; 
L@GzP IN: 
OR_IN ; 
OUTPUT ; 
PRESSED = 
Q_ LOC ; 

CK ; 
CLEAR ; 
be 
PRESE 


Q; 
EDGE STRIGGEREDsD =: 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D :; 


ed) 


Q; 
EDGE. TRIGGERED SD:: 
EDGE_TRIGGERED_D : 
BDGEZTRICGGEREDED = 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE. TRIGCEREDEDS: 
EDGE_TRIGGERED_D : 
EDGE _TRIGGEREDED : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D’; 
EDGE TRIGGEREDED.. 
EDGE: TRIGGERED SD: 
EDGE_TRIGGEREDSD =; 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGES TRI GGEREDSD =: 
EDGE _TRIGGERED_D ; 
EDGE_TRIGGERED_D : 


CK'DELAYED_26_5 ; 
CK'DELAYED_26_7 ; 
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CK' DELAYED_26_7'STABLE_26_ 9 ; 


CK'DELAYED_43_D ; 
CK'DELAYED_43_F ; 


CK' DELAYED_43_F'STABLE_43_H ; 


CK'DELAYED_52_I ; 


CK' DELAYED_52_1' STABLE as ea 


CK'STABLE_13_1 ; 
CK'STABLE_18_3 ; 
CK'STABLE_35_B ; 
CK STABLES 52 ain 
CK' STABLE_59_M ; 
D'STABLE_18_2 ; 

D'STABLE_26_4 ; 

GUARD ; 


PRESET' STABLE_35_A ; 
PRESET' STABLE 43._C ; 


S33 


CK: DELAYEDe26250. 
CK'DELAYED_26_7 ; 


CK'DELAYED 26_7'STABLE_26_9 ; 


CK'DELAYED_43_D ; 


/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 


/EP1 


Par 1. 


CON( 2) /CONTROL/D1. 
CON( 2) /CONTROL/D1. 
CON( 2) /CONTROL/D1. 
CON( 2) /CONTROL/D1. 
CON( 2) /CONTROL/D1. 
CON( 2) /CONTROL/D1. 
CON( 2) /CONTROL/D1. 
CON( 2) /CONTROL/D1. 
. CON( 2) /CONTROL/D1. 
CON( 2) /CONTROL/D1. 


ee =13-1988 14: 26:12 


~~ 


/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 


Er 1. 
pupil. 
yar 1. 


/EP1. 
/EP1. 
/EP1. 
/EP1. 


/EP1. 
/EP1. 
, /EP1. 


PEP. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 


CON(2)/CONTROL/D1. 
CON(2)/CONTROL/D1. 
CON(2)/CONTROL/D1. 
CON( 2) /CONTROL/D1. 
CON( 2) /CONTROL/D1. 


SONC3) : CLK’ TYPE_ 
CON(3) : PIN_1'DE 
CON(3)/CONTROL : 
CON(3)/CONTROL : 
CON(3) /CONTROL : 
CON(3)/CONTROL : 
CON(3)/CONTROL : 
CON(3)/CONTROL : 
CON(3)/CONTROL : 
CON(3)/CONTROL : 


CON(3)/CONTROL/D1 : 
CON(3)/CONTROL/D1 : 
CON(3)/CONTROL/D1 : 
CON(3)/CONTROL/D1 : 
CON(3)/CONTROL/D1 : 
CON(3)/CONTROL/D1. 
CON( 3) /CONTROL/D1. 
CON( 3) /CONTROL/D1. 
CON(3)/CONTROL/D1. 
CON( 3) /CONTROL/D1. 
CON(3)/CONTROL/D1. 
CON(3)/CONTROL/D1. 
CON(3)/CONTROL/D1. 
CON(3)/CONTROL/D1. 
CON(3)/CONTROL/D1. 
CON(3)/CONTROL/D1. 
CON(3)/CONTROL/D1. 
CON(3) /CONTROL/D1. 
CON(3) /CONTROL/D1. 
CON(3)/CONTROL/D1. 
CON(3)/CONTROL/D1. 
CON(3) /CONTROL/D1. 
CON(3)/CONTROL/D1. 
CON( 3) /CONTROL/D1. 


CON(4) : CLK' TYPE 
CON(4) : PIN_1'DE 
CON(4)/CONTROL : 


EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 


CK' DELAYED_43_F ; 
CK'DELAYED_43_F'STABLE_ 43_H ; 
CK'DELAYED_52_1 ; 
CK'DELAYED_52_I'STABLE_52_K ; 


CK'STABLE_13_1 ; 
CK'STABLE_18_3 ; 
CK'STABLE_35_B ; 
CK' STABLE_52_L ; 
CK'STABLE_59_M ; 
D'STABLE_18 2 ; 


VHDL Simulator 
SIGNAL NAME MAP 


KERNEL = 


SONY 79 6 
LAYED_79 _A; 
CLEAR ; 
CLK ; 
FEEDBACK : 
home IN; 
ORZIN 3 
GCUTRUT : 
RE ore: 
OBEOC 3 
on 
CLEAR ; 


De, 
PRESET ; 


_CONV_79_C ; 
LAYED_79_A ; 
CLEAR ; 
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EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 


QO; 
EDGE_TRIGGERED D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 


<<SHU>>TEST_EP3 


D'STABLE_26_4 ; 
GUARD ; 


PRESET’ STABLE_35_A ; 
PRESET'STABLE_43_C ; 


S 3 


Ck DELAYED=26.5 - 


b 


CK' DELAYED_26_7 ; 


CK'DELAYED_26_7'STABLE_26_9 ; 


CK' DELAYED_43_D ; 
CK'DELAYED_43_F ; 
CK'DELAYED_43_F'STABLE_43_H ; 
CK'DELAYED_52_I ; 
CK' DELAYED_52_I'STABLE_52_K ; 


Che STABLE. 13.1% 
CK'STABLE_18_3 ; 
CK'STABLE_35_B ; 
CK'STABLE_52_L ; 
CK'STABLE_59_M ; 
D'STABLE_18_2 ; 

D'STABLE_26_4 ; 

GUARD ; 


PRESET 'STABLE_35_A ; 


PRESET 'STABLE_43_C ; 


S 5 


3 


PAGE 3 


3 


/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 


/EP1. 
/EP1. 
/EP1. 
/EP1. 


/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 


CON(4)/CONTROL : 
CON(4)/CONTROL : 
CON(4)/CONTROL : 
CON(4)/CONTROL : 
CON(4)/CONTROL : 
CON(4)/CONTROL : 
CON(4)/CONTROL : 
CON(4)/CONTROL/D1 : 


CON(4)/CONTROL/D1 : 
CON(4)/CONTROL/D1 : 
CON(4)/CONTROL/D1 : 


CON(4)/CONTROL/D1 : 


CON(4)/CONTROL/D1. 
CON( 4) /CONTROL/D1. 


DEC-13-=1988 Was 2ocr 


. CON(4) /CONTROL/D1. 
. CON(4)/CONTROL/D1. 
. CON(4) /CONTROL/D1. 
. CON(4)/CONTROL/D1. 
. CON(4) /CONTROL/D1. 
.CON(4) /CONTROL/D1. 
. CON(4) /CONTROL/D1. 
.CON(4)/CONTROL/D1. 
. CON(4)/CONTROL/D1. 
.CON(4) /CONTROL/D1. 
. CON(4) /CONTROL/D1. 
. CON(4) /CONTROL/D1. 
. CON(4) /CONTROL/D1. 
. CON(4) /CONTROL/D1. 
.CON(4) /CONTROL/D1. 
. CON(4) /CONTROL/D1. 
. CON( 4) /CONTROL/D1. 
.CON(5) : 
.CON(S) : 


CLK' TYPE 
PIN_1'DE 
CON(5)/CONTROL : 


.CON(5)/CONTROL : 
.CON(5)/CONTROL : 
.CON(5)/CONTROL : 
.CON(5)/CONTROL : 
.CON(5)/CONTROL : 
.CON(5)/CONTROL : 
.CON(5)/CONTROL : 
-CON(5)/CONTROL/D1 ; 
.CON(S)/CONTROL/D1 : 
.CON(5)/CONTROL/D1 : 
.CON(5)/CONTROL/D1 : 
.CON(5)/CONTROL/D1 : 
. CON(5 ) /CONTROL/D1. 
.CON(5) /CONTROL/D1. 
.CON(5) /CONTROL/D1. 
. CON(5) /CONTROL/D1. 
. CON(5) /CONTROL/D1. 
. CON(5)/CONTROL/D1. 


CTs: 
FEEDBACK ; 
HOZP IN ; 
OR_IN ; 
OUREUT =; 
PRESET ; 
Q_LOC ; 

CK s 
vlgeer : 
D 
PRESET ; 


Q; 
EDGE_TRIGGERED_D : 


EDGES TRIGEERE DSi: 


CK'DELAYED_26_5 ; 
CK'DELAYED_26_7 ; 


VHDL Simulator 
SIGNAL NAME MAP 
KERNEL = <<SHU>>TEST_EP3 


_CONV_79¢.; 
LAYED_79_A ; 
CLEAR ; 
CLK ; 
FEEDBACK ; 
IO_PIN ; 
OR_IN ; 
OURPUR: 
PRESE 
Q_ LOC 
CK 
CLEAR : 


D ; 
PRESET ; 
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EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 


Q ; 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 


PAGE 4 


CK' DELAYED_26_7'STABLE_26_9 ; 


CK' DELAYED_43_D 
CK'DELAYED_43_F 


CK' DELAYED_43_F' STABLE_ 43_H ; 


CK' DELAYED_52_I : 


CK'DELAYED_52_I'STABLE_52_K ; 


CK' STABLE _13010- 
CK'STABLE_18_ 3 ; 
CK'STABLE_35_B ; 
CK STABLE 52 ube. 
CK' STABLE_59_M ; 
D'STABLE_18_2 ; 
D'STABLE_26_4 ; 
GUARD ; 


PRESET' STABLE_35_A ; 
PRESET’ STABLE_43_C ; 


5 5 


CK'DELAYED_26_5 ; 
CK'DELAYED_26_7 ; 


CK'DELAYED_26_7'STABLE_26_9 ; 


CK'DELAYED_43_D ; 
CK'DELAYED_43_F ; 


CK' DELAYED _43_F'STABLE_43_H ; 


/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 


CON(5)/CONTROL/D1. 
CON(5) /CONTROL/D1. 
CON(5) /CONTROL/D1. 
CON(5) /CONTROL/D1. 
CON(5) /CONTROL/D1. 
CON(5) /CONTROL/D1. 
CON(5) /CONTROL/D1. 
CON(5) /CONTROL/D1. 
CON(5)/CONTROL/D1. 
CON(5)/CONTROL/D1. 
CON(5) /CONTROL/D1. 
CON(5)/CONTROL/D1. 
CON( 5) /CONTROL/D1. 


CON(6) : CLK’ TYPE 
CON(6) : PIN_1'DE 
CON(6)/CONTROL : 
CON(6)/CONTROL : 
CON(6)/CONTROL : 


DEG-13-1988 14: 26:12 


.CON(6)/CONTROL : 
.CON(6)/CONTROL : 
.CON(6)/CONTROL : 
.CON(6)/CONTROL : 
.CON(6)/CONTROL : 

.CON(6)/CONTROL/D1 : 
.CON(6)/CONTROL/D1 : 
.CON(6)/CONTROL/D1 : 
.CON(6)/CONTROL/D1 : 
.CON(6)/CONTROL/D1 : 
. CON(6) /CONTROL/D1. 
. CON(6) /CONTROL/D1. 
. CON(6) /CONTROL/D1. 
. CON( 6) /CONTROL/D1. 
. CON(6) /CONTROL/D1. 
. CON(6) /CONTROL/D1. 
. CON(6) /CONTROL/D1. 
. CON(6) /CONTROL/D1. 
. CON(6) /CONTROL/D1. 
. CON(6) /CONTROL/D1. 
. CON(6) /CONTROL/D1. 
. CON(6) /CONTROL/D1. 
. CON(6) /CONTROL/D1. 
. CON(6) /CONTROL/D1. 
. CON(6) /CONTROL/D1. 
. CON( 6) /CONTROL/D1. 
. CON(6)/CONTROL/D1. 
. CON(6) /CONTROL/D1. 
. CON( 6) /CONTROL/D1. 
.CON(7) : 
.CON(7) : 
.CON(7)/CONTROL : 

.CON(7)/CONTROL : 
.CON(7)/CONTROL : 


Giik, TYPE 
PIN_1'DE 


MCONY 79_C ; 
LAYED_ 79 ASS 
CLEAR ; 

CiKe: 
FEEDBACK ; 


HEGE Se IRIGGEREDsl) : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
BDGESGRIGGERED D ; 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGES TRIGGERED D : 
HODGES TRIGGERED D 
EDGE_TKIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
BUGE TRIGGERED D : 


GK PELAYED 5201 


3 


CKADELAYED 5201 STABLE 52 K ; 


CK'STABLE_13_1 ; 
CK'STABLE_18 3 
CK'STABLE_35_B 
CK'STABLE 52_L 
CK'STABLE 59_M 
D'STABLE_18 2 ; 
D'STABLE_26_4 ; 
GUARD ; 


we we Wwe we 


PRESET’ STABLE_35_A ; 
PRESET’ STABLE _43_C ; 


S 5 


VHDL Simulator 
SIGNAL NAME MAP 
KERNEL = <<SHU>>TEST_EP3 


1O.PiEN ye 
ORSIN:. 
OUTPUT ; 

FM SE 

Q LOC ; 
Gis 
CLEAR ; 
D ; 
PRESET 3 


_CONV_79_C 
LAYED_79_A ; 
CLEAR ; 

CLK ; 
FEEDBACK ; 


Is, 


Q ; 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED _D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED _D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED _D : 
EDGE_TRIGGERED_D : 


CK' DELAYED_26_5 
CK'DELAYED_26_7 


CK DELAYED_26_7'STABLE_26_9 


CK' DELAYED_43_D 
CK' DELAYED_43_F ; 


3 


3 


3 
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b 


CK'DELAYED_43_F'STABLE_43_H ; 
CK'DELAYED_52_1 ; 


CK'DELAYED_52_I'STABLE_52_K ; 


CK'STABLE_13_1 ; 
CK SMABLE._18 37: 
CK'STABLE_35_B ; 
CK STABLE 52 20a. 
CK'STABLE_59_M ; 
D'STABLE_18_2 ; 

D'STABLE_26_4 ; 

GUARD ; 


PRESET’ STABLE_35_A ; 
PRESET'STABLE_43_C ; 


S ; 


/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 
/EP1. 


CON(7)/CONTROL : 
CON(7)/CONTROL : 
CON(7)/CONTROL : 
CON(7)/CONTROL : 
CON(7)/CONTROL : 


CON(7)/CONTROL/D1 : 
CON(7)/CONTROL/D1 : 
CON(7)/CONTROL/D1 : 
CON(7)/CONTROL/D1 : 
CON(7)/CONTROL/D1 : 
CON(7)/CONTROL/D1. 
CON(7)/CONTROL/D1. 
CON(7)/CONTROL/D1. 
CON(7)/CONTROL/D1. 
CON( 7) /CONTROL/D1. 
CON(7)/CONTROL/D1. 
CON(7)/CONTROL/D1. 
CON(7)/CONTROL/D1. 
CON(7)/CONTROL/D1. 
CON(7)/CONTROL/D1. 
CON( 7) /CONTROL/D1. 
CON(7)/CONTROL/D1. 


DEG=15-—1966ule: 26-12 


.CON( 7) /CONTROL/D1. 
.CON(7)/CONTROL/D1. 
. CON( 7) /CONTROL/D1. 
. CON( 7) /CONTROL/D1. 
. CON(7) /CONTROL/D1. 
. CON(7) /CONTROL/D1. 
. CON( 7) /CONTROL/D1. 
.CON(8) : 
.CON(8) : 

-CON(8)/CONTROL : 

.CON(8)/CONTROL : 
.CON(8)/CONTROL : 
.CON(8)/CONTROL : 
.CON(8)/CONTROL : 
.CON(8)/CONTROL : 
.CON(8)/CONTROL : 
.CON(8)/CONTROL : 

.CON(8)/CONTROL/D1 : 
.CON(8)/CONTROL/D1 : 
.CON(8)/CONTROL/D1 : 
.CON(8)/CONTROL/D1 : 
.CON(8)/CONTROL/D1 : 
. CON(8) /CONTROL/D1. 
. CON(8) /CONTROL/D1. 
. CON(8) /CONTROL/D1. 
. CON(8) /CONTROL/D1. 
. CON(8)/CONTROL/D1. 
. CON(8) /CONTROL/D1. 
. CON(8) /CONTROL/D1. 
. CON(8) /CONTROL/D1. 


Clie TYPE 
PIN_1'DE 


TOBPRIN -: 
ORGIN ; 
OUTPUT ; 
PREOEL ; 
OZEOC ; 
GK. 
CLEAR ; 
D ; 
PRES. 3 


Q; 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGESTR IGGEREDED: 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 


CK'DELAYED_26_5 ; 
CK' DELAYED_26_7 ; 


CK'DELAYED_26_7'STABLE_26_ 9 ; 


CK'DELAYED_43_D ; 
CK'DELAYED_43_F ; 


CK' DELAYED_43_F' STABLE_43_H ; 


CK'DELAYED_52_I ; 


bd 


CK'DELAYED_52_I'STABLE_52_ K ; 


CK'STABLE_13_1 ; 
CK'STABLE_18 3 ; 
CK'STABLE_35_B ; 
GK STApIEn: S2osine. 


VHDL Simulator 
SIGNAL NAME MAP 


KERNEL = 


=GONV.7 JEGs: 
LAYED_79_A ; 
CLEAR ; 

CLK ; 
FEEDBACK ; 
TOLPIN ; 

OR nN. 
OUREUT = 
EReonl 

G7 LOG; 
CK: 
CLEAR ; 
D ; 
PREOEa @ 
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EDGE_TRIGGERED_D : 
EDGESIRIGGERE Ds) = 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 


OF 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 
EDGE_TRIGGERED_D : 


<<SHU>>TEST_EP3 


CK'STABLE_59_M ; 
D'STABLE_18_2 ; 
D'STABLE_26_4 ; 
GUARD ; 


PRESET ' STABLE_35_A ; 
PRESET ' STABLE_43_C ; 


5 3 


GR DELAYED 2625. 
CK DELAYEDEZ607 =. 
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CK'DELAYED_26_7'STABLE_26_9 ; 


CK'DELAYED_43_D ; 
CK'DELAYED_43_F ; 


CK'DELAYED_43_F'STABLE_43_H ; 


CK'DELAYED_52_I ; 


CK' DEGAYED_52_1 STABLE 52ahe 


CK'STABLE_13_1 
CK'STABLE_18_ 3 
CK'STABLE_35_B 


/EP1. CON( 8) /CONTROL/D1. EDGE_TRIGGERED_D : 
/EP1. CON(8)/CONTROL/D1. EDGE_TRIGGERED_D : 
/EP1. CON( 8) /CONTROL/D1. EDGE_TRIGGERED_D : 
/EP1. CON(8)/CONTROL/D1. EDGE_TRIGGERED_D : CK'STABLE_52_L 
/EP1. CON(8)/CONTROL/D1. EDGE_TRIGGERED_D : CK'STABLE_59_M 
/EP1. CON(8)/CONTROL/D1. EDGE_TRIGGERED_D : D'STABLE_18_2 ; 
/EP1.CON(8)/CONTROL/D1. EDGE_TRIGGERED_D : D'STABLE_26_4 ; 
/EP1. CON(8)/CONTROL/D1. EDGE_TRIGGERED_D : GUARD ; 

/EP1. CON(8)/CONTROL/D1. EDGE_TRIGGERED_D : PRESET'STABLE_35_A ; 
/EP1. CON(8)/CONTROL/D1. EDGE_TRIGGERED_D : PRESET'STABLE_43_C ; 
/EP1. CON(8)/CONTROL/D1. EDGE_TRIGGERED_D: S; 


wetwe we we we 


/EP1.M(1)/MACRO : A(1 TO 18) ; 
/EP1.M(1)/MACRO : EN ; 
/EP1.M(1)/MACRO : EN_LOC ; 
/EP1.M(1)/MACRO : LOC(1 TO 8) ; 
/EP1.M(1)/MACRO : OR_OUT ; 


/EP1.M(1)/MACRO. P(1)/ELEMENT : P_OUT ; 
/EP1.M(1)/MAGRO. P(1)/ELEMENT : X(1 TO 18) ; 
/EP1.M(1)/MACRO. P(2)/ELEMENT : P_OUT ; 
/EP1.M(1)/MACRO. P(2)/ELEMENT : X(1 TO 18) ; 
/EP1.M(1)/MACRO. P(3)/ELEMENT : P_OUT ; 
/EP1.M(1)/MACRO. P(3)/ELEMENT : X(1 TO 18) ; 
/EP1.M(1)/MAGRO. P(4)/ELEMENT : P_OUT ; 
/EP1. M(1)/MAGRO. P(4)/ELEMENT : X(1 TO 18) ; 
/EP1.M(1)/MACRO. P(5)/ELEMENT : P_OUT ; 
/EP1.M(1)/MACRO. P(5)/ELEMENT : X(1 TO 18) ; 


DEC-13-1988 14: 26:12 VHDL Simulator 
SIGNAL NAME MAP 


KERNEL = <<SHU>>TEST_EP3 


PAGE 7 


fee MC 1) /MACRO. P(6) /ELEMENT : P_OUT ; 
eran 1) /MACRO. P(6)/ELEMENT : X(1 TO 18) ; 
pier tMC1)/MACRO. P(7)/ELEMENT : P_OUT ; 

Pee MC 1) /MAGRO. P(7)/ELEMENT : X(1 TO 18) ; 
fee eMC 1)/MACRO. P(8)/ELEMENT : P_OUT ; 

foe te MC 1) /MACRO. P(8)/ELEMENT : X(€1 TO 18) ; 
moet tC))/MACRO/OE : P_OUT ; 
Peretti 1) /MACRO/OE : X(1 TO 18) ; 
feet tC 2)/MACRO : A(1 TO 18) ; 

Peete MCZ)/MACRO : EN ; 

fee deMi(2)/MACRO : EN_LOC ; 

meee MC 2)/MACRO : LOC(1 TO 8) ; 

Peewee ti(2)/MACRO : OR_OUT ; 

/EP1.M(2)/MACRO. P(1)/ELEMENT : P_OUT ; 
Pople (2) /MAGRO. P(1)/ELEMENT : X€1 TO 18) ; 
fisted MC 2) /MACRO. P( 2) /ELEMENT : P_OUT ; 
pee. MC 2) /MACRO. P(2)/ELEMENT : 4(1 TO 18) ; 
fee (2) /MACRO, P(3)/ELEMENT : P_OUT ; 
feet 2) /MACRO. P(3)/ELEMENT : X(1 TO 18) ; 
VEEL. MC 2) /MACRO. P(4)/ELEMENT : P_OUT ; 

fee 1. HC 2) /MACRO. P(4)/ELEMENT : X(1 TO 18) ; 
pee MC 2) /MACRO. P(5)/ELEMENT : P_OUT ; 
perl. M€2)/MACRO. P(5)/ELEMENT : X(1 TO 18) ; 
pee d. hi( 2) /MACRO. P(6)/ELEMENT : P_OUT ; 
Peed. MC 2) /MAGRO. P(6)/ELEMENT : X(1 TO 18) ; 
pete Ve M( 2) /MACRO, P(7)/ELEMENT : P_OUT ; 
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/EP1.M(2)/MACRO. P(7)/ELEMENT : X(€1 TO 18) ; 
/EP1.M(2)/MACRO] PCS) /BREMENTS: Ps@uUaie 
/EP1.M(2)/MAGROSPCS) /ELEMENTO: X( 2eTeRis a 
/EP1. MC2) /MACKO7 OL. eaeun 
/EP1.M( 2) /MAGRO? OE. sei Omrs ) *; 
/EP1.MC3) /MACRO - 2 AGI ST Omte; 
JEP1-MC3) /MACRO Vee 
/EP1. MC3) (MACROS ENS LOC 
/EP1.M(3)/MACRO]= = LOCC reiGm.o))) : 
/EP1.MC3 )/ MACRO@ = SOheoU ie. 
/EP1.M(3)/MACRO. P(1)/ELEMENT : P_OUT ; 
/EP1. MC3) /MACROSPCL) /ELEMEND SG bee rce. 
/EP1.M(3)/MACRO. P( 2) / ELEMENT = Seem. 
/EP1. M(3) /MAGRO: PC Z) /ELEMENT = X@te io 16) =. 
/EP1. MC3) /MAGRO: P(3)/ELEMEND 7) Paoul = 
/EP1.MC3)/MAGRO: P(3) /ELEMENT <sxX@ialOe ic =. 
/EP1.MC3) /MACRODP(4 ) /ELEMENP = Se aoure. 
/EP1.M(3)/MACRO. P(4)/ELEMENT : X(i TO 18) ; 
/EP1.MC3) /MACRO. P(5)/ELEMENT ©) Paoun.. 
/EP1. MC3) /MACRO. P(5)/ELEMENT = Gi toes) = 
/EP1. M(3) /MACRO: P(6:) /ELEMENT eae ue 
/EP1.M(3) /MACRO: PCG) /ELEMENT = genesis 
/EP1.M(3)/ MACRO: P( 7) /ELEMENT > Paeuie. 
/EP1. MC3) /MACRO. PC 7) /ELEMENT eG Ome soe. 
/EP1.M(3) /MAGRO: P(8)/ ELEMENT = =) suis. 
/EP1. MC3) /MACRO. P(8)/ELEMEST iG r@mira) 
JEP1.MC3 )/ MACRO, OF: “POU. 
/EP1.MC3) /MACRO/OE = XC las@ws 
/EP1.M(4)/MACRO : A(1 TO 18) ; 
/EP1.M(4)/MACRO : EN ; 
DEC-13-1988 14: 26: 12 VHDL Simulator 
SIGNAL NAME MAP 
KERNEL = <<SHU>>TEST_EP3 
/EP1. M(4)/ MACRO) EN=LOG]: 
/EP1.MNC4)/ MACROM SLOG Ghee 2s ya. 
/EP1.MG4) /MACKOw SS OR OURS, 
J/EP1- C4) MACROS EG) / ELEMENT = P20 he 
J/EP1.MC4) /MACRO@EC1) /ELENENT = XC Tee re. 
/EP1.M(4) /MACRO. P(2)/ELEMENT : P_OUT ; 
/EP1.MC4) /MACRO@PC2) /ERBMENT = “(iene eis je- 
J/EPIMC4 yy MACRO ECS ) / ELEMENT =: sr. Oui. 
/EP1. MCG) /MACROVP( 3) / ELEMENT = XC PO ton 
/EP1.M(4) /MACRO. P(4)/ELEMENT : P_OUT ; 
/EP1.M(4)/MACROs P(4) /ELEMENT = XC1) Goss); 
/EP1.M(4)/MACRO. P(5)/ELEMENT : P_OUT ; 
/EP1.M(4) /MAGRO;PCU5)) ELEMENT = 1) Toile. 
/EP1. MC4)/MACRO; PC6),/ ELEMENT :. Peeve: 
/EP1.MC4) /MACRO. PC6) /ELEMENT =) XC 
/EP1.M(4)/MACRO. P(7)/ELEMENT ;: PlOUT.; 
/EP1.MC4) /MACRO. P(7)/BELEMENT = XG@ie TOs) 
/EP1.MNC4) /MACRO PC8)/ ELENEND = Seaoete. 
/EP1. M(4) /MACRO. PC&) / ELEMENT > XG@ieOwr Ss i; 
JEPIM( 4) / MACRO OE@ 2 r OUnere 
/EP1.M(4) /MAGRO/OE = .Cl ies 
/EP1. MUS) /MAGROW SAC 1 TO tee 
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/EP1.M(5)/MACRO : EN ; 

/EP1.M(5)/MACRO : EN_LOC ; 

/EP1.M(5)/MACRO : LOC(1 TO 8) ; 
/EP1.M(5)/MACRO : OR_OUT ; 

/EP1.M(5)/MACRO. P(1)/ELEMENT : P_OUT ; 
/EP1.M(5)/MACRO. P(1)/ELEMENT : X(1 TO 18) ; 
/EP1.M(5)/MACRO. P(2)/ELEMENT : P_OUT ; 
/EP1.M(5)/MACRO. P(2)/ELEMENT : X(1 TO 18) ; 
/EP1.M(5)/MACRO. P(3)/ELEMENT : P_OUT ; 
/EP1.M(5)/MACRO. P(3)/ELEMENT : X(1 TO 18) ; 
/EP1.M(5)/MACRO. P(4)/ELEMENT : P_OUT ; 
/EP1.M(5)/MACRO. P(4)/ELEMENT : X(1 TO 18) ; 
/EP1.M(5)/MACRO. P(5)/ELEMENT : P_OUT ; 
/EP1.M(5)/MACRO. P(5)/ELEMENT : X(1 TO 18) ; 
/EP1.M(5)/MACRO. P(6)/ELEMENT : P_OUT ; 
/EP1.M(5)/MACRO. P(6)/ELEMENT : X(1 TO 18) ; 
/EP1.M(5)/MAGRO. P(7)/ELEMENT : P_OUT ; 
/EP1.M(5)/MACRO. P(7)/ELEMENT : X(1 TO 18) ; 
/EP1.M(5)/MACRO. P(8)/ELEMENT : P_OUT ; 
/EP1.M(5)/MACRO. P(8)/ELEMENT : X(1 TO 18) ; 
/EP1.M(5)/MACRO/OE : P_OUT ; 
/EP1.M(5)/MACRO/OE : X(1 TO 18) ; 
/EP1.M(6)/MACRO : A(1 TO 18) ; 
/EP1.M(6)/MACRO : EN ; 

/EP1.M(6)/MACRO : EN_LOC ; 

/EP1.M(6)/MACRO : LOC(1 TO 8) ; 
/EP1.M(6)/MACRO : OR_OUT ; 

/EP1.M(6)/MACRO. P(1)/ELEMENT : P_OUT ; 
/EP1.M(6)/MACRO. P(1)/ELEMENT : X(1 TO 18) ; 
/EP1.M(6)/MACRO. P(2)/ELEMENT : P_OUT ; 
/EP1.M(6) /MACRO. P(2)/ELEMENT : X(1 TO 18) ; 
/EP1.M(6)/MACRO. P(3)/ELEMENT : P_OUT ; 
/EP1.M(6)/MACRO. P(3)/ELEMENT : X(1 TO 18) ; 
/EP1.M(6)/MACRO. P(4)/ELEMENT : P_OUT ; 
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/EP1.M(6)/MACRO. P(4)/ELEMENT : X(1 TO 18) ; 
/EP1.M(6)/MACRO. P(5)/ELEMENT : P_OUT ; 
/EP1.M(6)/MACRO. P(5)/ELEMENT : X(1 TO 18) ; 
/EP1.M(6)/MACRO. P(6)/ELEMENT : P_OUT ; 
/EP1.M(6)/MACRO. P(6)/ELEMENT : X(1 TO 18) ; 
/EP1.M(6)/MAGCRO. P(7)/ELEMENT : P_OUT ; 
/EP1.M(6)/MACRO. P(7)/ELEMENT : X(1 TO 18) ; 
/EP1.M(6)/MACRO. P(8)/ELEMENT : P_OUT ; 
/EP1.M(6)/MACRO. P(8)/ELEMENT : X(1 TO 18) ; 
/EP1.M(6)/MACRO/OE : P_OUT ; 
/EP1.M(6)/MACRO/OE : X(1 TO 18) ; 
/EP1.M(7)/MACRO : A(1 TO 18) ; 
/EP1.M(7)/MACRO : EN ; 

/EP1.M(7)/MACRO : EN_LOC ; 

/EP1.M(7)/MACRO : LOC(1 TO 8) ; 
/EP1.N(7)/MACRO : OR_OUT ; 

/EP1.M(7)/MACRO. P(1)/ELEMENT : P_OUT ; 
/EP1.M(7)/MACRO. P(1)/ELEMENT : X(1 TO 18) ; 


shies 


/EP1.MC7) /MACRO. PC 2) /ELEMENT : Paeume 

/EP1.MC7) /MACRO. P(2Z)/ BEEMENT = XG Romie a: 

/EP1. M(7) /MACRO. P(3)/ELEMENT : POUT; 

(EP1.M(C7) /MACRO. PC3)/EGEHENT <" ACTS hOmig ie: 

/EP1.M(7)/MACRO. P(4)/ELEMENT : P_OUT ; 

/EP1.M(7)/MACRO. P(4)/ELEMENT : X(1 TO 18) ; 

/EP1. MC 7) /MACRO. P(5)/ELEMENT : P_OUT = 

/EP1.M(7) /MACRO. P(5) 7 ELEMENT > XQ 

/EP1.MC7) /MACRO: PC6)) ELEMENT =F Oui 

/EP1. MC7) /MAGRO: P(C6) /EEEMENT <Geeewre ee 

J/EP1. MC 7) /MACRKO. PC7)/ ELEMENT = Peer ie 

/EP1. MC7 ) /MACRO. PC7)/ ELEMENT =: XGleeG als 

/EP1.M(7 ) /MACRO. PC8)/ ELEMENT © Paci. 

/EP1.M(C7 ) /MACRO: P(8) /ELEMENT =: XC Oars) S 

/EP1I.MC7 ) /MACRO/ Ob ee OUle. 

/EP1. MC7) /MACRO/OE = Gime a 1S): 

/EP1.MC8) /MACRO™: ACG e Lome: 

/EP1: MCS )/ HACK Ome rines 

/EP1.M(8)/MACRO : EN_LOC ; 

/EP1.MC8) /MACRO- LOCGle Toes jr. 

/EPI.MCS& )/ MACRO]. = OR 200 ie 

/EP1.MC8) /MAGRO. PC) ELEMENT; Peoun.. 

/EP1.MC8)/MACRO. P(1)/ELEMENT ; XO OSes: 

/EP1.MC8)/MACRO. P( 2) 7 BLEMENG Se aout 

/EP1.MC8)/MACRO. PC2 7 BLENENI > XG@ipetOes i: 

/EP1.MC8)/MACRO-. P(3) /ELEMENT ==" Peel. 

/EP1.MC8 )i/MACRO- P( 3 ) (ELEMENT <= XC Toes ye: 

/EP1.M(8)/MACRO. P( 4) /ELEMENT : P_OUT ; 

/EP1.MC8) /MACRO. PC 4) / ELEMENT = Xe Ors): 

, EPI. MC8)/MACRO. P(5)/ ELEMENT =~ POUT 

+ &P1.M(C8)/MACRO, PC5 )/ELEMENT : Gi romie 

/EP1.M(8)/MACRO. P(6)/ELEMENT <;) Peoul 

/EP1.M(C8) /MACRO. P( 6) /ELEMENT : X(1 TO 18) ; 

/EP1.MC8) /MACRO. PC 7} / BLEMEND =P OUT 

/EP1.M(8) /MACRO. PC7)/ ELENEND = Xie Romie. - 

/EP1.MC8)/MACRO: PCS) ELEMEND = Ve OU 

/EP1. MC8)/MACRO. PCS) /BLEMEND == XC) Toa 

/EF1.NC8) MACRO, OF ee raoct an 
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/EP1.M(8)/MACRO/OE : X(1 TO 18) ; 
/EP1/P : P_OUT ; 

JEPA/ Pe XC ro) lene 

/EP1/R : P_OUT ; 

/EP1/R : X(1 TO 18) ; 
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APPENDIX D. MACRO VAX/VMS SYSTEM COMMAND 


A. MACRO VAX/VMS SYSTEM COMMAND FOR EP310 MODEL 


!FILE NAME: Batch (for EP310 model) 
Sset def [ shu. vhdl. altera] 

Sset verify 

Svls setlib shu 

Svhdl eprom_pack 

Smg eprom_pack 

Smg/body eprom_pack 

Sset def [ shu. vhdl. altera. ep310] 
Sset verify 

Svls setlib ep310 

Svhdl ep310_pack 

Smg ep310_pack 

Smg/body ep310_pack 

Svhdl d_reg 

Smg d_register(behavioral_2) 
Svhdl p_term 

Smg p_term( behavioral) 

Svhdl macrocell 

Smg macrocell( behavioral) 

Svndl 10 control 

Smg io_control(behavioral_1) 
Svhdl ep310 

Smg ep310(structural) 

sset def [shu. vhdl. altera. ep310. test] 
Sset verify 

Svls setlib shu 

Svhdl test_bench 

Svhdl test_ep310 

smg/top test_bench(ep310) 
Sbuild/replace/ker=test_ep3 test_bench(ep310) 
Ssim test_ep3/param=20000000 ,4 
Srg test_ep3 test_ep310.rcl 
Sexit 


Fe? 


B. MACRO VAX/VMS SYSTEM COMMAND FOR EP1800 MODEL 


!FILE NAME: Batch (for EP1800 model) 
Sset def [{shu. vhdl. altera] 

Sset verify 

Svils setlib shu 

Svhdl eprom_pack 

Smg eprom_pack 

Smg/body eprom_pack 

Sset def [shu. vhdl. altera. ep1800] 
Sset verify 

Svls setlib ep1800 

Svhdl ep1800_pack 

Smg ep1800_pack 

Smg/body ep1800_pack 

Svhdl d_reg 

Smg d_register( behavioral) 

Svhdl p_term 

Smg p_term( behavioral) 

Svhdl io_control 

Smg io_control(behavioral) 

Svhdl local_m 

Smg local_macrocell(structural) 
Svhdl global_m 

Smg global_macrocell(structural) 
Svhdl quadrant 

Smg quadrant(structural) 

Svhdl ep1800 

Smg ep1800(structural) 

Sset def [{shu. vhdl. altera. ep1800. test] 
Sset verify 

Svls setlib shu 

Svhdl test_bench 

Svhdl test_ep1800 

Smg/top test_bench(ep1800) 
Sbuild/replace/ker=test_count test_bench(ep1800) 
Ssim test_count/para=0,20/trace=select. signal 
Srg test_count test_ep1800. rcl 

Sexit 


Ae 
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